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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



The present document covers the minimum characteristics considered necessary in order to provide comphance to 

TS 31.130 [2]. 

The present document describes the technical characteristics and methods of test for testing the (U)SIM API for Java 
Card™ (TS 31.130 [2]) implemented in the (U)SIM. It specifies the following parts: 

- test applicability; 

test environment description; 

tests format; 

test area reference; 

conformance requirements; 

test suite files; 

test procedure; 

test coverage; and 

a description of the associated testing tools that shall be used. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] ETSI TS 101 220: "Integrated Circuit Cards (ICC); ETSI numbering system for 

telecommunication; Application providers (AID)". 

[2] 3GPP TS 31 130 Release 6: "(U)SIM API for Java Card™" 

[3] ETSI TS 102 241 : "UICC Application Programming Interface (UICC API) for Java Card (TM); 

(Releasee)". 

[4] 3GPP TS 3 1 . 1 02: "Characteristics of the USIM Application" . 

[5] 3GPP TS 5 1 .01 1 Release 4: "Specification of the Subscriber Identity Module- Mobile Equipment 

(SIM -ME) interface". 

[6] 3GPP TS 23.041: "Technical reaHzation of Cell Broadcast Service (CBS)". 

[7] ETSI TS 102 223 Release 6: "Card AppHcation Toolkit (CAT)". 

[8] 3GPP TS 31.1 1 1: "USIM Application Toolkit (US AT)". 

[9] 3GPP TS 5 1 .014 Release 4: "Specification of the SIM Application Toolkit for the Subscriber 

Identity Module - Mobile Equipment (SIM - ME) interface". 

[10] 3GPP TS 31.1 15: "Secured packet structure for the (U)SIM Toolkit applications". 
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[11] 3GPP TS 23.040: "Technical reaHzation of the Short Message Service (SMS)". 

[12] Sun Microsystems Java Card^M Specification: "Java Card^^ 2.2.1 Application Programming 

Interface". 

[13] Sun Microsystems Java Card^M Specification: "Java Card'"'^ 2.2.1 Runtime Environment (JCRE) 

Specification". 

[14] Sun Microsystems Java Card'''^ Specification: "Java Card''^ 2.2.1 Virtual Machine Specification". 

SUN Java Card'^^ Specifications can be downloaded at http://iava.sun.com/products/iavacard 

[15] ETSI TS 102 268: "Test specification for UlCC Application Programming Interface for Java Card 

(TM); (Release 6)". 

[16] 3GPP TR 21.905: "Vocabulaiy for 3GPP Specifications". 



3 Definitions, symbols and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in TR 21.905 [16] and the following apply. A 
term defined in the present document takes precedence over the definition of the same term, if any, in TR 2 1 .905 [ 16] . 

applet installation parameters: values for applet installation parameters 

Conformance Requirement Reference (CRR): description of the expected card behaviour according to TS 31.130 [2] 

expected state: state in which the (U)SIM is supposed to be after the execution of the test procedure applied on the 
relevant initial conditions 

security parameters: minimum security requirements defined for the applet installation process 

test area: set of Test Cases applicable to a specific part (class method, CAT RE behaviour, etc) of the TS 31.130 [2]. 

test case: elementary test that checks for compliance with one or more Conformance Requirement References 

test procedure: sequence of actions/commands to perform all the test cases defined in a test area 

test source file: Java file containing methods that will load and install test applet in the card, execute and verify the test 
results, and restore the Default Initial Conditions on the (U)SIM (when possible). 

test toolkit applet: applet designed to test a specific functionality of the USIM API (TS 31.130 [2]) 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in TR 21.905 [16] and the following apply. An 
abbreviation defined in the present document takes precedence over the definition of the same abbreviation, if any, in 
TR 21.905 [16]. 

AID Application IDentifier 

APDU Application Protocol Data Unit 

API Application Programming Interface 

CAT RE Card Application Toolkit Runtime Environment 

CRR Conformance requirements Reference 

CRRC Conformance requirement Reference Context Error 

CRRN Conformance requirement Reference Normal 

CRRP Conformance requirement Reference Parameter Error 

FFS For Further Study 
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Test environment 



This clause specifies requirements that shall be met and the testing rules that shall be followed during the test 
procedure. 



4.1 



Applicability 



The tests defined in the present document shall be performed taking into account the services supported by the card as 
specified in the EFsst file. 

The test defined in the present document are applicable to cards implementing TS 31.130 [2] unless otherwise stated. 

The tests defined in the present document require that the card support the concatenation process with 2 concatenated 
SMS. 



4.2 Test environment description 

The general architecture for the test environment is; 



' Scope of the Test Suite. 
. Elements of the Test Suite 
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and Java CardT" 



Conversion 
parameters 
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installation 
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Applications 
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ADF File system 
Server 



Other 

Applications 
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31 130 



Toolkit Applet 

(e.g. Toolkit 

Service, Remoh 

Management 

Applications, 

Browser 

Applications) 



Java Card™ 
package 



uicc. access 
packages 



uicc.toolkit 
package 



uicc.system 
package 



uicc.usim. 
access 
package 



uicc.usim. 
toolkit 
package 



APDU 



Java Card" Runtime Environment 



(U)SATFramework 



USAT EvelopeHandler 



CAT Runtime Environment 



Toolkit 
Handlers 



Toolkit 
Registry 



Triggering 
Entity 
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4.3 Tests format 
4.3.1 Test area reference 

Each test area is referenced as follows: 
For API testing: 

API Testing: 'API_[package name]_[classname]_[methodname]' where 
package name: 

uicc.usim.access package: T 
uicc.usim.toolkit package: '2' 
class name: 

yyy: 3 letters for each class. 
See Annex A for full classes acronyms list, 
method name: 

zzzz [input parameters]: 

See Annex A for full methods name acronyms list. 
For Framework testing: 
FWK: framework testing 
Chapter name: 

xxx: 3 letters for each chapter 
See annex F for full chapter acronyms list 
Subchapter name 

yyyy: : 4 letters for each subchapter 

See annex F for full subchapter acronyms list 

4.3.1.1 Conformance requirements 

The conformance requirements are expressed in the following way: 

- Method prototype as listed in TS 3 1 . 1 30 [2] . 

Normal execution: 

Contains normal execution and correct parameters limit values, each referenced as a Conformance 
Requirement Reference Normal (CRRN). 

Parameters error: 

Contains parameter errors and incorrect parameter limit values, each referenced as a Conformance 
Requirement Reference Parameter Error (CRRP). 

Context error: 

Contains errors due to the context the method is used in, each referenced as a Conformance Requirement 
Reference Context Error (CRRC). 
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4.3.1.2 Test area files 

The files included in the Test Area use the following naming convention: 

Test Source: Test_[Test Area Reference]. Java 

Test Applet: [Test Area Reference]_[Test applet number] .Java 

Cap File: [Test Area Reference]. cap 
The applet numbers start from '1'. 

The test source shall use common interfaces defined in Annex D. 
The Cap File format is described in Java Card^"^ Virtual Machine Specification [4]. 
Test files can be run in any order. 
All files from the same test area are located in the same subfolder. 

4.3.1 .3 Test procedure 

Each test procedure contains a table to indicate the expected responses form the API and/or the APDU level as follows: 



Test Case 


Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Test Case detailed description 


API and/or (U)SAT Framework 
expected behaviour. 


Expected response at APDU 
level. 



4.3.1 .4 Test coverage 

The table above each test procedure indicates the correspondence between the Conformance Requirements Reference 
(CRR) and the different test cases. 

4.4 Initial conditions 

The Initial Conditions are a set of general prerequisites for the (U)SIM prior to the execution of testing. For each test 
procedure described in the present document, the following rules apply to the Initial Conditions: 

unless otherwise stated, the file system and the files' content shall fulfil the requirements described in annex B; 

unless otherwise stated, before installing the applet(s) relevant to the current test procedure, all packages specific 
to other test procedures shall not be present. 

When both statements apply, a test procedure is said to be in the "Default Initial Conditions" state. 

4.5 Package name 

Java packages integrating this Test Suite shall follow this naming convention: 

uicc.usim.test.access.[Test Area Reference]: Java Card packages containing Test Area References for the 
TS 31.130 [2] uicc. access package. 

uicc.usim.test.toolkit.[Test Area Reference]: Java Card packages containing Test Area References for the 
TS 31.130 [2] uicc.toolkit package. 

uicc.usim.test.usatframework.[Test Area Reference]: Java Card packages containing Test Area References for the 
TS 31.130 [2] US AT Framework. 
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uicc.usim.test.util: for the Test util package defined in this Test Suite. 

where the Test Area Reference is written in lower case. 

EXAMPLE: The package ../uicc.usim.test.access. [Test Area Reference] creates the following directory 
Structure ../uiccusim//test/access/[TestArea Reference]/Api_l _..._[!. .n].*, where 
Api_l _..._[ l..n].*' are the different test applets Java source files used in [Test Area Reference] . 



4.6 AID coding 



The AID coding for the Test Packages, Applet classes and Applets shall be as specified in ETSI TS 101 220 [5]. In 
addition, the following TAR and Application Provider specific data values are defined for use within the present 
document: 



AID coding 




Byte 12 | Byte 13 | Byte 14 | Byte 15 | Byte 16 



Application Provider specific data 



TAR 



Specified in ETSI TS 101 220 [5] 



TAR coding (3 bytes/ 24 bits): 



1 b1 1 


1 b4 1 b5 1 


1 b8 1 b9 1 


|b12|b13| 


|b16|b17| 


|b24| 






















Applet instance number 




Applet class number 










Package number 












RFU 














Test Part Identifier 



Applet instance number. Applet Class number. Package number: 

For package AID, package number shall start from and class and instance numbers shall be 0. 

For class AID, package number is the number of the class package, class number shall start from 1 and instance 
shall be 0. 

For instance AID, package and class number are the number of class and package of which instance belongs, and 
instance number shall start from 1 . 

Test part Identifier (bits bl-b4): 

• 0000 reserved (as TAR= '00.00.00' is reserved for Issuer Security Domain) 

• 0010 API uicc.usim.toolkit 

• 1 lUS AT Framework 

• lllOUSIMADF 

• nil uicc.util 

• other values are RFU 
Application Provider specific data (1 byte): 

• '00' for Package 

• 'Or for Applet class 
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• '02' for Applet Instance 

EXAMPLE: The AID of Package uicc.usim.util is 'AO 00 00 00 87 10 05 FF FF FF FF 89 FO 00 00 00'. 

4.7 Test equipment 

These clauses recommend a minimum specification for each of the items of test equipment referenced in the tests. 

4.7.1 Test tool 

This test tool shall meet the following requirements: 

be able to send and receive APDU command to the USIM; 

the result of I/O commands must be presented at the application layer; 

be able to provide results of the tests; 

shall send and/or compare all data specified in test file; 

4.7.2 Interfaces and classes use 

The USIM test tool extends the UICC test tool defined in ETSI TS 102 268 [15]. Then The USIM test tool cannot be 
run without having implemented the UICC test tool. 

The USIM test tool shall use some interfaces and classes, defined in Annex D. They define the only allowed methods to 
write the test sources. 

Interfaces and classes are defined as follow: 

USimToolkitService defines methods to manage toolkit commands, 

USimAPITestService defines methods to send envelopes defined in TS 3 1 . Ill [8], 

USimAPITestCardService defines the static method to get a reference of the class implementing all 
interfaces. 

4.7.3 Util package 

Annex D includes Java source code of TestToolkitApplet abstract class of the uicc.usim.util package. Each test applet 
shall extend this abstract class in order to retrieve test results when selecting it. 

4.7.4 Java Software Development kit version 

Java software development kit (SDK) version supported by Java Card 2.2.1 specifications ([12], [13], [14]) is 1.4.1. 



Test plan 



The test plan is divided according to the (U)SIM API specification, that way the tests will follow the class hierarchy for 
the uicc.usim. toolkit and uicc.usim.access package; for the SIM Toolkit framework this test plan describes the different 
points that will be tested with the present test specification. 

5.1 Package uicc.usim.access package 
5.1 .1 Interface SllVIConstants 
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The constants in Java are resolved at compilation time, therefore a runtime test is not useful. No test of constants will be 
performed. 

5.1.2 Interface USIMConstants 

The constants in Java are resolved at compilation time, therefore a runtime test is not useful. No test of constants will be 
performed. 

5.2 Package uicc.usim.toolkit package 

5.2.1 Interface ToolkitConstants 

The constants in Java are resolved at compilation time, therefore a runtime test is not useful. No test of constants will be 
performed. 

5.2.2 Interface USATEnvelopeHandler 

5.2.2.1 Method getSecureclDataLength 

Test Area Reference: Api_2_Ueh_Gsdl 

5.2.2.1.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getSecuredDataLength ( ) 

throws uicc. toolkit. Toolkit Except ion 

5.2.2.1 .1 .1 Normal execution 

• CRRN 1 : The method shall return the length of the Secured Data from the Command Packet in the SMS TPDU 
(simple or concatenated) or Cell Broadcast Page Comprehension TLV contained in the Envelope handler. 

• CRRN2: The length is from the first SMS TPDU TLV or Cell Broadcast Page Comprehension TLV. 

• CRRN3: The length should not include padding bytes. 

• CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV and if the SMS 
TP-UD is formatted according to TS 31.115 [10] Single or Concatenated Short Message. 

• CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD and if the SMS 
TP-UD is formatted according to TS 31.115 [10] Single or Concatenated Short Message. 

• CRRN6: The method can be used if the event is EVENT_FORMATTED_SMS_CB and if the Cell Broadcast 
Page is formatted according to TS 31.115 [10]. 

• CRRN7: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_ENV, the selected 
TLV should be the SMS TPDU TLV. 

• CRRN8: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_UPD, the selected 
TLV should be the SMS TPDU TLV. 

• CRRN9: If the method is successful and if the event is EVENT_FORMATTED_SMS_CB, the selected TLV 
should be the Cell Broadcast Page TLV. 

5.2.2.1.1.2 Parameter errors 
No requirements. 
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5.2.2.1.1.3 



Context errors 



• CRRC 1 : The method shall throw ToolkitException.UNAV AILABLE_ELEMENT in case of unavailable SMS 
TPDU TLV element or Cell Broadcast Page Comprehension TLV. 

• CRRC2: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of wrong data format. 

5.2.2.1.2 Test area files 

Specific triggering: 

- FORMATTED SMS CB. 

- UNFORMATTED SMS CB. 

- FORMATTED SMS PP ENV. 

- UNFORMATED SMS PP ENV. 

- FORMATTED SMS PP UPD. 

For Formatted triggering if CC/RC/DS is used, the security parameters are the one defined in section "5.3.8 
Framework Security Management". 



Test Source: 
Test Applet: 
Cap File: 

5.2.2.1.3 



Test_Api_2_Ueh_Gsdl.j ava 
Api_2_Ueh_Gsdl_ 1 .j ava 
Api_2_Ueh_Gsdl.cap 

Test coverage 



CRR number 


Test case number 


N1 


1 to 42 


N2 


13,30 


N3 


6, 7, 23, 24, 37, 38 


N4 


1 to 17 


N5 


1 8 to 34 


N6 


35 to 42 


N7 


17 


N8 


34 


N9 


42 


CI 


43 


C2 


44 



5.2.2.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP ENV Triggering 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Test with FORMATTED SMS PP ENV and TP- 
OA length of 2 


Returns 0x002A 




2 


Test with TP-OA length of 6 


Returns 0x002A 




3 


Test with TP-OA length of 12 


Returns 0x002A 




4 


Test with RC/CC/DS length of 


Returns 0x0010 




5 


Test with RC/CC/DS length of 8 


Returns 0x0010 




6 


Test with PCNTR = 


Returns 0x0010 




7 


Test with PCNTR = 7 (ciphering shall be used) 


Returns 0x0003 




8 


Test with Secured Data Length = 00 


Returns 0x0000 




9 


Test with Secured Data Length = 0x33 


Returns 0x0033 




10 


Test with Secured Data Length = 0x6C (UDL = 
0x7F) 


Returns 0x006C 




11 


Test with Secured Data Length = 0x6D (DDL = 
0x80) 


Returns 0x006D 




12 


Test with Secured Data Length = maximum length 
for one envelope : 0x79 (DDL = 0x8C) 


Returns 0x0079 




13 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV and inside two 

different secured data lengths: 5 and 10 


Returns 0x0005 




14 


Test with secured data length = 0x7F (2 
concatenated envelopes are needed) 


Returns 0x007F 




15 


Test with secured data length = 0x80 (2 
concatenated envelopes are needed) 


Returns 0x0080 




16 


Test with secured data length = maximum length 
for 2 concatenated envelopes : OxFA 


Returns OxOOFA 




17 


Test with FOR MATTE D_SMS_PP_ENV 
Verify after call of the method the current TLV is 
the TPDU TLV: 

findTLV device identities, getSecuredDataLength 
and then getValueByte to verify that the current 
TLV is the TPDU TLV 


getValueByte returns 0x0040 






FORMATTED SMS PP UPD Triggering 






18 


Same test as 1 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x002A 




19 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns 0x002A 




20 


Same test as 3 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x002A 




21 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns 0x0010 




22 


Same test as 5 but with 
FORMATTED SMS PP UPD 


Returns 0x0010 




23 


Same test as 6 but with 
FORMATTED SMS PP UPD 


Returns 0x0010 




24 


Same test as 7 but with 
FORMATTED SMS PP UPD 


Returns 0x0003 




25 


Same test as 8 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x0000 




26 


Same test as 9 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x0033 




27 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x006C 




28 


Same test as 1 1 but with 
FORMATTED SMS PP UPD 


Returns 0x006D 




29 


Same test as 1 2 but with 
FORMATTED SMS PP UPD 


Returns 0x0079 




30 


Same test as 13 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x0005 




31 


Test with secured data length = 0x7F (2 
concatenated envelopes are needed) 


Returns 0x007F 




32 


Test with secured data length = 0x80 (2 
concatenated envelopes are needed) 


Returns 0x0080 




33 


Test with secured data length = maximum length 
for 2 concatenated envelopes : OxFA 


Returns OxOOFA 




34 


Test with FORMATTED SMS PP UPD 


getValueByte returns 0x0040 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Verify after call of the method the current TLV is 
the TPDU TLV: 

findTLV device identities, getSecuredDataLength 
and then getValueByte to verify that the current 
TLV is the TPDU TLV 








FORMATTED SMS CB Triggering 






35 


Same test as 4 but with FORMATTED SMS CB 


Returns 0x0010 




36 


Same test as 5 but with FORMATTED SMS CB 


Returns 0x0010 




37 


Same test as 6 but with FORMATTED SMS CB 


Returns 0x0010 




38 


Same test as 7 but with FORMATTED SMS CB 


Returns 0x0003 




39 


Same test as 8 but with FORMATTED SMS CB 


Returns 0x0000 




40 


Same test as 9 but with FORMATTED SMS CB 


Returns 0x0033 




41 


Same test as 12 but with maximum secured data 
length: 0x42, and FORMATTED SMS CB 


Returns 0x0042 




42 


Test with FORMATTED_SMS_CB 

Verify after call of the method the current TLV is 

the Cell Broadcast Page TLV: 

findTLV device identities, getSecuredDataLength 

and then getValueByte to verify that the current 

TLV is the Cell Broadcast Page TLV 


getValueByte returns 0x00 






Error tests 






43 


Send an envelope SMS CB, 
getSecuredDataLength 


ToolkitException. UNAVAILABLE E 
LEMENT 




44 


Send an envelope SMS PP unformatted 


ToolkitException. UNAVAILABLE E 
LEMENT 





5.2.2.2 Method getSecuredDataOffset 

Test Area Reference: Api_2_Ueh_Gsdo 

5.2.2.2.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getSecuredDataOf f set ( ) 

throws uicc. toolkit. ToolkitException 

5.2.2.2.1.1 Normal execution 

• CRRNl: The method shall return the offset of the secured data first byte contained in a SMS TPDU TLV. 

• CRRN2: The offset is from the first SMS TPDU TLV. 

• CRRN3: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV and if the SMS TP- 
UD is formatted according to TS 31.115 [10]. 

• CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD and if the SMS TP- 
UD is formatted according to TS 31.115 [10]. 

• CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_CB and if the Cell Broadcast 
Page is formatted according to TS 31.115 [10]. 

• CRRN6: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_ENV, the selected 
TLV should be the SMS TPDU TLV. 

• CRRN7: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_UPD, the selected 
TLV should be the SMS TPDU TLV. 

• CRRN8: If the method is successful and if the event is EVENT_FORMATTED_SMS_CB, the selected TLV 
should be the Cell Broadcast Page TLV. 
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• CRNN9: If the Secured Data length is zero the value returned shall be the offset of the first byte following the 
TS 31.115 [10] Command Packet structure. 



5.2.2.2.1.2 

No requirements. 

5.2.2.2.1.3 



Parameter errors 



Context errors 



• CRRC 1 : The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of unavailable SMS 
TPDU TLV element. 

• CRRC2: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of wrong data format. 

5.2.2.2.2 Test area files 

Specific triggering: 

- FORMATTED SMS CB. 

- UNFORMATTED SMS CB. 

- FORMATTED SMS PP UPD. 

- FORMATTED SMS PP ENV. 

- UNFORMATED SMS PP ENV. 

For Formatted triggering if CC/RC/DS is used, the security parameters are the one defined in section "5.3.8 
Framework Security Management". 



Test Source: 
Test Applet: 
Cap File: 

5.2.2.2.3 



Test_Api_2_Ueh_Gsdo.j ava 
Api_2_Ueh_Gsdo_ 1 .j ava 
Api_2_Ueh_Gsdo .cap 

Test coverage 



CRR number 


Test case number 


N1 


1 to 20 


N2 


5,13 


N3 


1 to 8 


N4 


9 to 16 


N5 


17, 18, 19,20 


N6 


7 


N7 


15 


N8 


20 


N9 


6, 14, 19 


C1 


21 


C2 


22 



5.2.2.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP ENV triggering 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Test with TP-OA length of 2 and RC/CC/DS length 
isO 


Returns 0x21 




2 


Test with TP-OA length of 6 and RC/CC/DS length 
isO 


Returns 0x23 




3 


Test with TP-OA length of 1 2 and RC/CC/DS 
length is 


Returns 0x26 




4 


Test with RC/CC/DS length of 8 and TP-OA length 
is 2 


Returns 0x29 




5 


Send a SMS PP with 2 TPDU TLV and inside two 
different secured data offsets 


Returns 0x24 ( the first offset ) 




6 


Same test as 1 but without any secured data 


Returns 0x21 




7 


Test with FORMATTED_SMS_PP ENV 

Verify after call of the method the current TLV is 

the TPDU TLV: 

findTLV device identities, getSecuredDataOffset 

and then getValueByte to verify that the current 

TLV is the TPDU TLV 


Returns 0x40 




8 


Same test as 1 , but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = OxOOFA) 


Returns 0x21 






FORMATTED SMS PP UPR triggering 






9 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x21 




10 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns 0x23 




11 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x26 




12 


Same test as 4 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x29 




13 


Same test as 5 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x24 ( the first offset ) 




14 


Same test as 6 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x21 




15 


Test with FORMATTED_SMS_PP UPD 

Verify after call of the method the current TLV is 

the TPDU TLV: 

findTLV device identities, getSecuredDataOffset 

and then getValueByte to verify that the current 

TLV is the TPDU TLV 


Returns 0x40 




16 


Same test as 8, but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = OxOOFA) 


Returns 0x21 






FORMATTED SMS CB triggering 






17 


Same test as 2 but with FORMATTED SMS CB 


Returns 0x16 




18 


Same test as 4 but with FORMATTED SMS CB 


Returns 0x1 E 




19 


Same test as 6 but with FORMATTED SMS CB 


Returns 0x16 




20 


Test with FORMATTED_SMS_CB 

Verify after call of the method the current TLV is 

the Cell Broadcast Page TLV: 

findTLV device identities, getSecuredDataOffset 

and then getValueByte to verify that the current 

TLV is the Cell Broadcast Page TLV 


Returns 0x00 






UNFORMATTED Triggering 






21 


Send an UNFORMATTED SMS CB envelope, 
getSecu red DataOffset 


ToolkitException. UNAVAILABLE E 
LEMENT 




22 


Send an UNFORMATTED SMS PP envelope, 
getSecu red DataOffset 


ToolkitException. UNAVAILABLE E 
LEMENT 





5.2.2.3 Method getShortMessageLength 

Test Area Reference: Api_2_Ueh_Gsml 
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5.2.2.3.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getShortMessageLength ( ) 

throws uicc. toolkit. ToolkitExcept ion 

5.2.2.3.1.1 Normal execution 

• CRRN 1 : The method shall return the length of the Short Message from the User Data part in the SMS TPDU 
(simple or concatenated) or Cell Broadcast Page Comprehension TLV contained in the USATEnvelopeHandler. 

• CRRN2: The length is from the first SMS TPDU TLV or Cell Broadcast Page Comprehension TLV. 

• CRRN3: The length should not include padding bytes. 

• CRRN4: The length should not include the UDH if any. 

• CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV or 
EVENT_UNFORMATTED_SMS_PP. 

• CRRN6: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD or 
EVENT_UNFORMATTED_SMS_UPD. 

• CRRN7: The method can be used if the event is EVENT_FORMATTED_SMS_CB or 
EVENT_UNFORMATTED_SMS_CB. 

• CRRN8: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_ENV or 
EVENT_UNFORMATTED_SMS_PP, the selected TLV should be the SMS TPDU TLV. 

• CRRN9: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_UPD or 
EVENT_UNFORMATTED_SMS_UPD, the selected TLV should be the SMS TPDU TLV. 

• CRRN 10: If the method is successful and if the event is EVENT_FORMATTED_SMS_CB or 
EVENT_UNFORMATTED_SMS_CB, the selected TLV should be the Cell Broadcast Page TLV. 

• CRRN 1 1 : If the Short Message Length is zero, no exception shall be thrown. 

5.2.2.3.1.2 Parameter errors 
No requirements. 

5.2.2.3.1.3 Context errors 

• CRRC 1 : The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of unavailable SMS 
TPDU TLV element or Cell Broadcast Page Comprehension TLV. 



• 



CRRC2: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of wrong data format. 



5.2.2.3.2 Test area files 

Specific triggering: 

- FORMATTED SMS CB. 

- UNFORMATTED SMS CB. 

- FORMATTED SMS PP UPD. 

- UNFORMATTED SMS PP UPD. 

- FORMATTED SMS PP ENV. 

- UNFORMATTED SMS PP ENV. 
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UNRECOGNIZED_ENVELOPE. 

For Formatted triggering if CC/RC/DS is used, the security parameters are the one defined in section "5.3.8 
Framework Security Management". 



Test Source: 
Test Applet: 
Cap File: 

5.2.2.3.3 



Test_Api_2_Ueh_Gsml.j ava 
Api_2_Ueh_Gsml_ 1 .j ava 
Api_2_Ueh_Gsml.cap 

Test coverage 



CRR number 


Test case number 


N1 


1 to 46 


N2 


8, 18,26,34,41,45 


N3 


4, 14,22 


N4 


1 to 27 


N5 


1 to 10 and 28 to 35 


N6 


1 1 to 20 and 36 to 43 


N7 


21 to 27 and 44 to 46 


N8 


9,35 


N9 


19,43 


N10 


27,46 


N11 


6, 16,24,30,38 


C1 


47 


C2 


Not applicable 



5.2.2.3.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP ENV Triggering 






1 


Test with FORMATTED_SMS_PP_ENV and TP- 
OA length of 2 and secured data length of 0x2A 
with no padding byte (PCNTR = 0, no RC/CC/DS) 


Returns 0x003A 




2 


Test with TP-OA length of 1 2 and secured data 
length of 0x2A with no padding byte (PCNTR = 0, 
no RC/CC/DS) 


Returns 0x003A 




3 


Test with PCNTR = 0, no RC/CC/DS and data 
length of 0x10 


Returns 0x0020 




4 


Test with PCNTR = 7, no RC/CC/DS and data 
length of 0x03 (ciphering shall be used) 


Returns 0x001 A 




5 


Test with PCNTR = 0, with RC/CC/DS length of 8 
and secured data length of 0x1 


Returns 0x0028 




6 


Test with PCNTR = 0, no RC/CC/DS and 
SecuredDataLength = 00 


Returns 0x0010 




7 


Test with PCNTR = 0, no RC/CC/DS and 
UserDataLength = maximum length (0x8C) for a 
single SMS 


Returns 0x0089 




8 


Verify it is the first TPDU TLV: 
Send a SMS PP with 2 TPDU TLV with two 
different user data lengths: 0x18 and 0x23 (with 
PCNTR = 0, no RC/CC/DS) 


Returns 0x0015 




9 


Send envelope SMS-PP Formatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
getShortMessageLengthO and then 
getValueByteO with offset 


getValueByteO returns 
0x40(TS 23.040 [11] first byte) 




10 


Test with UserDataLength = maximum length 
(0x01 OD) with 2 concatenated SMS 


Returns 0x0 10A 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP UPD Triggering 






11 


Test with FORMATTED_SMS_PP_UPD and TP- 
OA length of 2 and secured data length of 0x2A 
with no padding byte (PCNTR = 0) 


Returns OxOOSA 




12 


Test with TP-OA length of 1 2 and secured data 
length of 0x2A with no padding byte (PCNTR = 0) 


Returns OxOOSA 




13 


Test with PCNTR = 0, no RC/CC/DS and data 
length of 0x10 


Returns 0x0020 




14 


Test with PCNTR = 7, no RC/CC/DS and data 
length of 0x03 (ciphering shall be used) 


Returns 0x001 A 




15 


Test with PCNTR = 0, with RC/CC/DS length of 8 
and secured data length of 0x1 


Returns 0x0028 




16 


Test with PCNTR = 0, no RC/CC/DS and 
SecuredDataLength = 00 


Returns 0x0010 




17 


Test with PCNTR = 0, no RC/CC/DS and 
UserDataLength = maximum length (0x8C) for a 
single SIVIS 


Returns 0x0089 




18 


Verify it is the first TPDU TLV: 
Send a SMS PP with 2 TPDU TLV with two 
different user data lengths: 0x18 and 0x23 (with 
PCNTR = 0, no RC/CC/DS) 


Returns 0x0015 




19 


Send envelope SIVIS-PP Formatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
GetShortMessageLengthO and then 
getValueByteO with offset 


GetValueByteO returns 
0x40(TS 23.040 [11] first byte) 




20 


Test with UserDataLength = maximum length 
(0x01 OD) with 2 concatenated SIVIS 


Returns 0x00 10A 






FORMATTED SMS CB Triggering 






21 


Test with PCNTR = 0, no RC/CC/DS and data 
length of 0x10 


Returns 0x0052 




22 


Test with PCNTR = 7, no RC/CC/DS and data 
length of 0x03 (ciphering shall be used) 


Returns 0x0052 




23 


Test with PCNTR = 0, with RC/CC/DS length of 8 
and secured data length of 0x1 


Returns 0x0052 




24 


Test with PCNTR = 0, no RC/CC/DS and 
SecuredDataLength = 00 


Returns 0x0052 




25 


Test with PCNTR = 0, no RC/CC/DS and 
UserDataLength = maximum length (0x58) for a 
single SIVIS CB 


Returns 0x0052 




26 


Verify it is the first Cell Broadcast Page TLV: 
Send a SMS CB with 2 Cell Broadcast Page TLV 
with two different user data lengths: 0x18 and 
0x23 (with PCNTR = 0, no RC/CC/DS) 


Returns 0x0052 and 
GetValueShort(6) returns 0x0016 
(UDL of first Page TLV) 




27 


Send envelope SMS-CB Formatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
GetShortMessageLengthO and then 
getValueByteO with offset 


GetValueByteO returns 0x00 (TS 
23.041 first byte) 






UNFORMATTED SMS PP ENV Triggering 






28 


Test with UNFORMATTED_SMS_PP_ENV and 
TP-OA length of 2, and user data length of 0x3D 


Returns 0x003D 




29 


Test with TP-OA length of 1 2, and user data length 
of 0x3 D 


Returns 0x003D 




30 


Test with UserDataLength = 0x00 


Returns 0x0000 with no exception 




31 


Test with UserDataLength = 0x7F 


Returns 0x007F 




32 


Test with UserDataLength = 0x80 


Returns 0x0080 




33 


Test with UserDataLength = maximum length: 
0x8C for a single SMS 


Returns 0x008C 




34 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x1 8 and 0x23 


Returns 0x0018 




35 


Send envelope SMS-PP Unformatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
getShortMessageLengthQ and then 
getValueByteO with offset (first user data = 
0x55) 


GetValueByteO returns 0x00 
(TS 23.040 [11] first byte) 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




UNFORMATTED SMS PP UPD Triggering 






36 


Test with UNFORMATTED_SMS_PP_UPD and 
TP-OA length of 2, and user data length of 0x3D 


Returns OxOOSD 




37 


Test with TP-OA length of 1 2, and user data length 
of 0x3 D 


Returns OxOOSD 




38 


Test with UserDataLength = 0x00 


Returns 0x0000 with no exception 




39 


Test with UserDataLength = 0x7F 


Returns 0x007F 




40 


Test with UserDataLength = 0x80 


Returns 0x0080 




41 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x1 8 and 0x23 


Returns 0x0018 




42 


Test with UserDataLength = maximum length: 
0x8C for a single SMS 


Returns 0x008C 




43 


Send envelope SMS-PP Formatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
GetShortMessageLengthO and then 
getValueByteO with offset 


GetValueByteO returns 0x00 
(TS 23.040 [11] first byte) 






UNFORMATTED SMS OB Triggering 






44 


Test with UNFORMATTED SMS CB 


Returns 0x0052 




45 


Verify it is the first Cell Broadcast Page TLV: 
Send a SMS CB with 2 Cell Broadcast Page TLV 
with two different user data lengths: 0x58 and 
0x23 


Returns 0x0052 




46 


Send envelope SMS-CB Formatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
GetShortMessageLengthO and then 
getValueByteO with offset 


GetValueByteO returns 0x00 (TS 
23.041 first byte) 






Unrecognized Envelope Triggering 






47 


Send an Unrecognized Envelope with neither 
TPDU TLV nor Cell Broadcast Page TLV, then call 
the method. 


ToolkitException. UNAVAILABLE E 
LEMENT 





5.2.2.4 Method getShortMessageOffset 

Test Area Reference: Api_2_Ueh_Gsmo 

5.2.2.4.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getShortMessageOf f set ( ) 

throws uicc. toolkit. ToolkitException 



5.2.2.4.1.1 



Normal execution 



CRRNl: The method shall return the offset of the Short Message first byte contained in the User Data part of the 
SMS TPDU TLV contained in the USATEnvelopeHandler. 

CRRN2: The offset is from the first SMS TPDU TLV. 

CRRN3: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV or 
EVENT_UNFORMATTED_SMS_PP_ENV. 

CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD or 
EVENT_UNFORMATTED_SMS_PP_UPD. 

CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_CB or 
EVENT_UNFORMATTED_SMS_CB. 

CRRN6: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_ENV or 
EVENT UNFORMATTED SMS PP ENV, the selected TLV should be the SMS TPDU TLV. 
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• CRRN7: If the method is successful and if the event is EVENT_FORMATTED_SMS_PP_UPD or 
EVENT_UNFORMATTED_SMS_PP_UPD, the selected TLV should be the SMS TPDU TLV. 

• CRRN8: If the method is successful and if the event is EVENT_FORMATTED_SMS_CB or 
EVENT_UNFORMATTED_SMS_CB, the selected TLV should be the Cell Broadcast Page TLV. 

• CRRN9: The method returns the offset of the first byte after the UDH, if any. 

5.2.2.4.1 .2 Parameter errors 
No requirements. 

5.2.2.4.1.3 Context errors 

• CRRC 1 : The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of unavailable SMS 
TPDU TLV or Cell Broadcast Page Comprehension TLV element. 

• CRRC2: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of wrong data format. 

5.2.2.4.2 Test area files 

Specific triggering: 

- FORMATTED SMS CB. 

- UNFORMATTED SMS CB. 

- FORMATTED SMS PP UPD. 

- UNFORMATTED SMS PP UPD. 

- FORMATED SMS PP ENV. 

- UNFORMATED SMS PP ENV. 

- UNRECOGNIZED_ENVELOPE. 

For Formatted triggering if CC/RC/DS is used, the security parameters are the one defined in section "5.3.8 
Framework Security Management". 



Test Source: 
Test Applet: 
Cap File: 

5.2.2.4.3 



Test_Api_2_Ueh_Gsmo.java 
Api_2_Ueh_Gsmo_ Lj ava 
Api_2_Ueh_Gsmo . cap 

Test coverage 



CRR number 


Test case number 


N1 


1 to 30 


N2 


4, 11,21,26 


N3 


1 to 7 and 19 to 23 


N4 


8 to 14 and 24 to 28 


N5 


15to18, 29, 30 


N6 


6,22 


N7 


13,27 


N8 


18,30 


N9 


1 to18, 23, 28 


C1 


31 


C2 


Not applicable 
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5.2.2.4.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP ENV triggering 






1 


Test with TP-OA length of 2 and RC/CC/DS length 
isO 


Returns 0x1 1 




2 


Test with TP-OA length of 1 2 and RC/CC/DS 
length is 


Returns 0x16 




3 


Test with RC/CC/DS length of 8 and TP-OA length 
is 2 


Returns 0x1 1 




4 


Send a SIVIS PP with 2 TPDU TLV and inside two 
different secured data offsets 


Returns 0x14 ( the first offset ) 




5 


Same test as 1 but without any secured data 


Returns 0x1 1 




6 


Test with FOR MATTE D_SMS_PP ENV 

Verify after call of the method the current TLV is 

the TPDU TLV: 

findTLV device identities, getSecuredDataOffset 

and then getValueByte to verify that the current 

TLV is the TPDU TLV 


Returns 0x40 




7 


Same test as 1 , but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = OxOOFA) 


Returns 0x15 






FORMATTED SMS PP UPD triggering 






8 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x1 1 




9 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns 0x16 




10 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x1 1 




11 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns0x14 ( the first offset ) 




12 


Same test as 5 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x1 1 




13 


Test with FORMATTED_SMS_PP UPD 

Verify after call of the method the current TLV is 

the TPDU TLV: 

findTLV device identities, getSecuredDataOffset 

and then getValueByte to verify that the current 

TLV is the TPDU TLV 


Returns 0x40 




14 


Same test as 10, but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = OxOOFA) 


Returns 0x21 






FORMATTED SMS CB triggering 






15 


Same test as 1 but with FORMATTED SMS CB 


Returns 0x06 




16 


Same test as 3 but with FORMATTED SMS CB 


Returns 0x06 




17 


Same test as 5 but with FORMATTED SMS CB 


Returns 0x06 




18 


Test with FORMATTED_SMS_CB 

Verify after call of the method the current TLV is 

the Cell Broadcast Page TLV: 

FindTLVO device identities, 

getSecuredDataOffsetO and then getValueByte() 

to verify that the current TLV is the Cell Broadcast 

Page TLV 


Returns 0x00 






UNFORMATTED SMS PP ENV triggering 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


19 


Test with TP-OA length of 2 


Returns 0x0 E 




20 


Test with TP-OA length of 12 


Returns 0x13 




21 


Send a SMS PP with 2 TPDU TLV and inside two 
different DDL offsets 


Returns 0x1 1 (the first offset) 












22 


Test with UNFORMATTED_SMS_PP ENV 
Verify after call of the method the current TLV is 
the TPDU TLV: 

findTLV device identities, getShortMessageOffset 
and then getValueByte to verify that the current 
TLV is the TPDU TLV 


Returns 00 




23 


Same test as 19, but with a concatenated SMS (2 
Short Messages and maximum User Data Length 
= 0x0102) 


Returns OxOE or OxOF (depending 
of UDHI implementation) 






UNFORMATTED SMS PP UPD triggering 






24 


Same test as 1 9 but with 
FORMATTED SMS PP UPD 


Returns OxOE 




25 


Same test as 20 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x13 




26 


Same test as 21 but with 
FORMA 1 IbD SMS PP UPD 


Returns 0x1 1 ( the first offset ) 












27 


Test with FORMATTED_SMS_UPD 

Verify after call of the method the current TLV is 

the TPDU TLV: 

findTLV device identities, getShortMessageOffset 

and then getValueByte to verify that the current 

TLV is the TPDU TLV 


Returns 0x1 1 




28 


Same test as 25, but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = OxOOFA) 


Returns OxOE or OxOF (depending 
of UDHI implementation) 






UNFORMATTED SMS CB Triggering 






29 


Test with UNFORMATTED SMS CB 


Returns 0x06 




30 


Send envelope SMS-CB Unformatted. 
FindTLVQ with TAG_DEVICE_IDENTITIES. 
getShortMessageOffsetO and then getValueByte{) 
with offset 


GetValueByteO returns 0x00 (TS 
23.041 first byte) 






Unrecognized Envelope Triggering 






31 


Send an Unrecognized Envelope with neither 
TPDU TLV nor Cell Broadcast Page TLV, then call 
the method. 


ToolkitException. UNAVAILABLE E 
LEMENT 





















5.2.2.5 Method getTPUDLOffset 

Test Area Reference: Api_2_Ueh_Gtpo 

5.2.2.5.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getTPUDLOf f set ( ) 

throws uicc. toolkit. ToolkitException 

5.2.2.5.1.1 Normal execution 

• CRRNl : The method shall return the TPUDL offset in a SMS TPDU TLV. 

• CRRN2: The offset is from the first SMS TPDU TLV. 

• CRRN3: The method can be used if the event is EVENT FORMATTED SMS PP ENV. 
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• CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD. 

• CRRN5: The method can be used if the event is EVENT_UNFORMATTED_SMS_PP_ENV. 

• CRRN6: The method can be used if the event is EVENT_UNFORMATTED_SMS_PP_UPD. 

• CRRN7: If the method is successful, the selected TLV should be the SMS TPDU TLV. 



5.2.2.5.1.2 

No requirements. 

5.2.2.5.1.3 



Parameter errors 



Context errors 



• CRRC 1 : The method shall throw ToolkitException.UNAVAILABLE_ELEMENT in case of unavailable SMS 
TPDU TLV element. 

• CRRC2: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT if the TPUDL field does not 

exist. 



5.2.2.5.2 Test area files 

Specific triggering: 

- FORMATTED SMS PP UPD. 

- UNFORMATTED SMS PP UPD. 

- UNFORMATTED SMS PP ENV. 

- FORMATTED SMS PP ENV. 

- UNFORMATTED SMS CB. 

Test Source Test_Api_2_Ueh_Gtpo.java 

Test Applet: Api_2_Ueh_Gtpo_l.java 

Cap File: Api_2_Ueh_Gtpo.cap 



5.2.2.5.3 



Test coverage 



CRR number 


Test case number 


N1 


1 to 21. 


N2 


4, 10, 15,20. 


N3 


1,2,3,4,5,6 


N4 


7,8,9, 10, 11 


N5 


12, 13, 14, 15, 16 


N6 


17, 18, 19,20,21 


N7 


6 


C1 


22 


C2 


Not testable 



5.2.2.5.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORMATTED SMS PP ENV triggering 
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1 


Test with TP-OA length of 2 


Returns OxOD 




2 


Test with TP-OA length of 6 


Returns OxOF 




3 


Test with TP-OA length of 12 


Returns 0x1 2 




4 


Send a SMS PP with 2 TPDU TLV and inside two 
different DDL offsets 


Returns 0x1 (the first offset) 




5 


Same test as 1 , but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = 0x00 FA) 


Returns OxOD 




6 


Verify after call of the method the current TLV is the 
TPDU TLV: 

findTLV device identities, getTPUDLOffset and then 
getValueByte to verify that the current TLV is the 
TPDU TLV 


Returns 0x40 






FORMATTED SMS PP UPD triggering 






7 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns OxOD 




8 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns OxOF 




9 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x1 2 




10 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns 0x1 (the first offset) 




11 


Same test as 7, but with a concatenated SMS (2 
Short Messages and maximum Secured Data 
Length = 0x00 FA) 


Returns OxOD 






UNFORMATTED SMS PP UPD triggering 






12 


Same test as 1 but with 
UNFORMAI IbD SMS PP UPD 


Returns OxOD 




13 


Same test as 2 but with 
UNFORMAI IbD SMS PP UPD 


Returns OxOF 




14 


Same test as 3 but with 
UNFORMAI IbD SMS PP UPD 


Returns 0x1 2 




15 


Same test as 4 but with 
UNFORMAI IbD SMS PP UPD 


Returns 0x12 (the first offset) 




16 


Same test as 12, but with a concatenated SMS (2 
Short Messages and maximum User Data Length = 
0x01 OC) 


Returns OxOD 






UNFORMATTED SMS PP ENV triggering 






17 


Same test as 1 but with 
UNFORMAI IbD SMS PP ENV 


Returns OxOD 




18 


Same test as 2 but with 
UNFORMAI IbD SMS PP ENV 


Returns OxOF 




19 


Same test as 3 but with 
UNFORMAI IbD SMS PP ENV 


Returns 0x1 2 




20 


Same test as 4 but with 
UNFORMAI IbD SMS PP ENV 


Returns 0x1 (the first offset) 




21 


Same test as 1 7, but with a concatenated SMS (2 
Short Messages and maximum User Data Length = 
0x01 OC) 


Returns OxOD 






UNFORMATTED SMS CB triggering 






22 


Send an envelope Unformatted SMS CB, 
getTPUDLOffset 


ToolkitException.UNAVAILABL 
E ELEMENT 





5.2.2.6 Method getUserDataLength 

Test Area Reference: Api_2_Ueh_Gudl 

5.2.2.6.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getUserDataLength ( ) 

throws uicc. toolkit. Toolkit Except ion 
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5.2.2.6.1.1 Normal execution 

• CRRN 1 : The method shall return the length of the User Data contained in the SMS TPDU TLV element. 

• CRRN2: The length is from the first SMS TPDU TLV element. 

• CRRN3: If the SMS TPDU TLV element is available, it becomes the selected TLV 

• CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV. 

• CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD. 

• CRRN6: The method can be used if the event is EVENT_UNFORMATED_SMS_PP_ENV. 

• CRRN7: The method can be used if the event is EVENT_UNFORMATTED_SMS_PP_UDP. 

5.2.2.6.1.2 Context errors 

• CRRCl : The method shall throw UNAVAILABLE_ELEMENT in case of unavailable TPDU TLV element. 

• CRRC2: The method shall throw UNAVAILABLE_ELEMENT in case of wrong data format. 

5.2.2.6.2 Test area files 

Specific triggering: 

- FORMATTED SMS PP UPD. 

- UNFORMATTED SMS PP UPD. 

- FORMATED SMS PP ENV. 

- UNFORMATED SMS PP ENV. 

For Formatted triggering if CC/RC/DS is used, the security parameters are the one defined in section "5.3.8 
Framework Security Management". 



Test Source: 
Test Applet: 
Cap File: 

5.2.2.6.3 



Test_Api_2_Ueh_Gudl.j ava 
Api_2_Ueh_Gudl_ 1 .j ava 
Api_2_Ueh_Gudl.cap 

Test coverage 



CRR number 


Test case number 


N1 


All test cases excepted: 
53 


N2 


11,26,37,45 


N3 


12,27,38,46 


N4 


1 to 15 


N5 


16 to 30 


N6 


31 to 38 


N7 


39 to 46 


CI 


47 


C2 


Not applicable 
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5.2.2.6.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




FORIVIATTED SMS PP ENV Triggering 






1 


Test with FORMATTED_SMS_PP_ENV and TP- 
OA length of 2 and user data length of 0x3D 


Returns 0x003D 




2 


Test with TP-OA length of 12 and user data length 
of 0x3 D 


Returns 0x003D 




3 


Test with RC/CC/DS length of and secured data 
length of 0x10 


Returns 0x0023 




4 


Test with RC/CC/DS length of 8 and secured data 
length of 0x10 


Returns 0x002B 




5 


Test with PCNTR = 0, no RC/CC/DS and data 
length of 0x10 


Returns 0x0023 




6 


Test with PCNTR = 7, no RC/CC/DS and data 
length of 0x03 (ciphering shall be used) 


Returns 0x001 D 




7 


Test with SecuredDataLength = 00 and no 
RC/CC/DS 


Returns 0x0013 




8 


Test with UserDataLength = 0x7F 


Returns 0x007F 




9 


Test with UserDataLength = 0x80 


Returns 0x0080 




10 


Test with UserDataLength = maximum length 
(0x8C) for a single SIVIS 


Returns 0x008C 




11 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x18 and 0x23 


Returns 0x0018 




12 


Send envelope SMS-PP Formatted. 
FindTLVO with TAG_DEVICE_IDENTITIES. 
GetUserDataLengthO and then getValueByte() 
with offset 


GetValueByteO returns 
Ox40(TS 23.040 [11] first byte) 




13 


Test with UserDataLength = OxFF with 2 
concatenated SMS 


Returns OxOOFF 




14 


Test with UserDataLength = 0x100 with 2 
concatenated SMS 


Returns 0x0100 




15 


Test with UserDataLength = maximum length 
(0x01 OD) with 2 concatenated SMS 


Returns 0x01 OD 






FORIVIATTED SMS PP UPD Triggering 






16 


Test with FORMATTED_SMS_PP_UPD and TP- 
OA length of 2 and user data length of 0x3D 


Returns 0x003D 




17 


Test with TP-OA length of 12 and user data length 
of 0x3D 


Returns 0x003D 




18 


Test with RC/CC/DS length of and secured data 
length of 0x10 


Returns 0x0023 




19 


Test with RC/CC/DS length of 8 and secured data 
length of 0x10 


Returns 0x002B 




20 


Test with PCNTR = 0, no RC/CC/DS and data 
length of 0x10 


Returns 0x0023 




21 


Test with PCNTR = 7, no RC/CC/DS and data 
length of 0x03 (ciphering shall be used) 


Returns 0x001 D 




22 


Test with SecuredDataLength = 00 and no 
RC/CC/DS 


Returns 0x0013 




23 


Test with UserDataLength = 0x7F 


Returns 0x007F 




24 


Test with UserDataLength = 0x80 


Returns 0x0080 




25 


Test with UserDataLength = maximum 
length(0x8C) for a single SMS 


Returns 0x008C 




26 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x18 and 0x23 


Returns 0x0018 




27 


Send envelope SMS-PP Formatted. 
FindTLVO with TAG_DEVICE_IDENTITIES. 
GetUserDataLengthO and then getValueByte() 
with offset 


GetValueByteO returns 
Ox40(TS 23.040 [11] first byte) 




28 


Test with UserDataLength = OxFF with 2 
concatenated SMS 


Returns OxOOFF 




29 


Test with UserDataLength = 0x100 with 2 


Returns 0x0100 
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concatenated SMS 






30 


Test with UserDataLength = maximum length 
(0x01 CD) with 2 concatenated SMS 


Returns 0x01 OD 






UNFORMATTED SMS PP ENV Triggering 






31 


Test with UNFORMATTED_SMS_PP_ENV and 
TP-OA length of 2, and user data length of 0x3D 


Returns OxOOSD 




32 


Test with TP-OA length of 12, and user data length 
of 0x3 D 


Returns OxOOSD 




33 


Test with UserDataLength = 0x00 


Returns 0x0000 




34 


Test with UserDataLength = 0x7F 


Returns 0x007F 




35 


Test with UserDataLength = 0x80 


Returns 0x0080 




36 


Test with UserDataLength = maximum length: 
0x8C for a single SMS 


Returns OxOOSC 




37 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x18 and 0x23 


Returns 0x0018 




38 


Send envelope SMS-PP Unformatted. 
FindTLVO with TAG_DEVICE_IDENTITIES. 
GetUserDataLengthO and then getValueByte() 
with offset (first user data = 0x55) 


GetValueByteO returns 0x00 
(TS 23.040 [11] first byte) 






UNFORMATTED SMS PP UPD Triggering 






39 


Test with UNFORMATTED_SMS_PP_UPD and 
TP-OA length of 2, and user data length of 0x3D 


Returns OxOOSD 




40 


Test with TP-OA length of 12, and user data length 
of 0x3 D 


Returns OxOOSD 




41 


Test with UserDataLength = 0x00 


Returns 0x0000 




42 


Test with UserDataLength = 0x7F 


Returns 0x007F 




43 


Test with UserDataLength = 0x80 


Returns 0x0080 




44 


Test with UserDataLength = maximum length: 
0x8C for a single SMS 


Returns OxOOSC 




45 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV with two 

different user data lengths: 0x18 and 0x23 


Returns 0x0018 




46 


Send envelope SMS-PP Unformatted. 
FindTLVO with TAG_DEVICE_IDENTITIES. 
GetUserDataLengthO and then getValueByte() 
with offset 


GetValueByteO returns 0x00 
(TS 23.040 [11] first byte) 






UNRECOGNIZED ENVELOPE Triggering 






47 


Test with an UNRECOGNIZED ENVELOPE 


ToolkitException. UNAVAILABLE E 
LEMENT 





5.2.2.7 Method getltem Identifier 

Test Area Reference: Api_2_Ueh_Giid 

5.2.2.7.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getltemldentif ier ( ) 

throws ToolkitException 

5.2.2.7.1.1 Normal execution 

• CRRNliThe method shall return the item identifier byte value. 

• CRRN2:The item identifier byte value returned shall be from the first Item Identifier TLV element. 

• CRRN3: If the element is available it becomes the TLV selected. 

• CRRN4: The item identifier is available for all triggered toolkit applets from the invocation to the termination of 
their processToolkit method if the US ATEnvelopeHandler is available. 
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5.2.2.7.1.2 

No requirements. 

5.2.2.7.1.3 



Parameter Errors 



Context errors 



CRRCl: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT if the item identifier TLV is 
not present. 

CRRC2: The method shall throw ToolkitException.OUT_OF_TLV_BOUND ARIES if the item identifier byte is 
missing in the Item Identifier Comprehension TLV. 



5.2.2.7.2 

Test Source: 
Test Applet: 
Cap File: 

5.2.2.7.3 



Test area files 

Test_Api_2_Ueh_Giid.j ava 
Api_2_Ueh_Giid_ 1 .j ava 
Api_2_Ueh_Giid.cap 

Test coverage 



CRR number 


Test case number 


N1 


1, 2, 3 


N2 


2,3 


N3 


4 


N4 


6 


01 


5 


C2 


7 



5.2.2.7.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Send envelope formatted SMS with an item 
identifier TLV and identifier value of 03 


Returns 03 




2 


Send envelope formatted SIVIS with two item 
identifier TLV with first value FF and second 44 


Returns FF 




3 


Send envelope formatted SIVIS with two item 
identifier TLV with first value 81 and second 44, 
call twice the method getltemldentifierQ 


Returns 81 
Returns 81 




4 


Send envelope formatted SMS with item identifier 
TLV and value of 66. FJndTLV{) with TAG 02. 
getltemldentifierO and then getValueByte{) with 
offset 


getltemldentifierO=getValueByteO 




5 


Send envelope formatted SMS without item 
identifier TLV and getltemldentifierO 


ToolkitException. UNAVAILABLE E 
LEMENT 




6 


Send envelope formatted SMS with item identifier 
TLV (66), send proactive command. Then 
getltemldentifierO 


Returns 66 




7 


Send envelope formatted SMS with item identifier 
TLV but without item number 


ToolkitException.OUT OF TLV B 
OUNDARIES 





5.2.2.8 Method getChannelldentifier 

Test Area Reference: Api_2_Ueh_Gcid 
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5.2.2.8.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getChannelldentif ier ( ) 

throws ToolkitException 

5.2.2.8.1.1 Normal execution 

• CRRNl: The method shall return the channel identifier byte value. 

• CRRN2: The channel identifier byte value returned shall be fi^om the first Channel status TLV element. 

• CRRN3: If the element is available it becomes the currently selected TLV. 

• CRRN4: The channel identifier is available for all triggered toolkit applets from the invocation to the termination 
of their processToolkit method if the US ATEnvelopeHandler is available. 



5.2.2.8.1.2 



Context errors 



CRRCl: The method shall throw ToolkitException.UNAVAILABLE_ELEMENT if the Channel status TLV is 
not present. 

CRRC2: The method shall throw ToolkitException.OUT_OF_TLV_BOUND ARIES if the Comprehension TLV 
Channel Status length is equal to 0. 



5.2.2.8.2 

Test Source: 
Test Applet: 
Cap File: 

5.2.2.8.3 



Test area files 

Test_Api_2_Ueh_Gcid.j ava 
Api_2_Ueh_Gcid_ 1 .j ava 
Api_2_Ueh_Gcid.cap 

Test coverage 



CRR number 


Test case number 


N1 


1,2 


N2 


3 


N3 


3 


N4 


5 


CI 


4 


02 


6 
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5.2.2.8.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 





1- Appletl is installed with maximum number of channel = 
07. 

2- Appletl builds proactive commands OPEN CHANNEL 
with InitQ method in order to open all channels. 
ProactiveHandler.sendO method is called. 




2- OPEN CHANNEL 
proactive command is 
fetched 

TERMINAL RESPONSE is 
issued with Channel Id from 
01 to 07 


1 


Successful Call 

1- Send envelope Event Download Channel Status with 
channel status TLV: 

channel status value = 0x8100. 

2- Call USATEnvelopeHandler.getChannelldentifierO 
method 


1- Appletl is triggered 

2- Returns 0x01 




2 


Two channel status elements 

1- Send envelope Event Download Channel Status with two 
channel status TLV: 

first value = 0x8400 
second value = 0x8500. 

2- Call twice the 
USATEnvelopeHandler.getChannelldentifierO method 


2- Returns twice 0x04 




3 


Verify current TLV 

1- Send envelope Event Download Channel Status with 
channel status TLV: 

Channel Status value = 0x0605 

ViewHandler.FindTLVO with Device Identity Tag. 

2- Call USATEnvelopeHandler.getChannelldentifierO 
method. 

3- Compare USATEnvelopeHandler.getChannelldentifier{) 
and then ViewHandler.getValueByte(O). 


2- Returns 0x06 

3- GetChannelldentifierO 
=getValueByte(0) 




4 


UNAVAILABLE_ELEMENT exception 

1- Send envelope Menu Selection without Channel Status 
TLV. 

2- Call USATEnvelopeHandler.getChannelldentifierO 
method. 


2- A Toolkit exception 
UNAVAILABLE_ELEMEN 
T is thrown. 




5 


Successful Call 

1- Send Envelope Event Download Channel Status with 
Channel Status TLV: 

Channel status value = 0x0600 

2- Call USATEnvelopeHandler.getChannelldentifier{) 
method. 


1- Returns 0x06 




6 


OUT_OF_TLV_BOUNDARIES exception 

1- Send unrecognized envelope with a Channel Status TLV 
having a length equal to 0. 

2- Call USATEnvelopeHandler.getChannelldentifier{) 
method. 


2- A Toolkit exception 
OUT_OF_TLV_BOUNDA 
RIES is thrown. 
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5.2.2.9 Method getChannelStatus 

Test Area Reference: Api_2_Ueh_Gcst 

5.2.2.9.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getChannelStatus (byte channelldentif ier) 

throws ToolkitException 



5.2.2.9.1.1 



Normal execution 



• CRRNl: The method shall return the value of the first Channel Status TLV element whose channel identifier is 
equal to the channelldentifier parameter. 

• CRRN2: The Channel Status value returned shall be from the element whose channel identifier is equal to the 
Channelldentifier parameter. 

• CRRN3: If the element is available it becomes the currently selected TLV. 

• CRRN4: The channel status is available for all triggered toolkit applets from the invocation to the termination of 
their processTooUcit method if the US ATEnvelopeHandler is available. 



5.2.2.9.1.2 



Context errors 



• CRRC 1 : The method shall throw ToolkitException.UNAVAILABLE_ELEMENT if no Channel Status TLV 
element with the right identifier could be found. 

• CRRC2: The method shall throw ToolkitException.OUT_OF_TLV_BOUND ARIES if a Channel Status TLV 
element with the right identifier could be found but its value is less than 2 bytes long. 



5.2.2.9.2 

Test Source: 
Test Applet: 
Cap File: 

5.2.2.9.3 



Test area files 

Test_Api_2_Ueh_Gcst.j ava 
Api_2_Ueh_Gcst_ 1 .j ava 
Api_2_Ueh_Gcst.cap 

Test coverage 



CRR number 


Test case number 


N1 


6 


N2 


5,7 


N3 


8 


N4 


9 


C1 


1,2 


C2 


3,4 



5.2.2.9.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 
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1- Appletl is installed with maximum number of 
channel = 01. 

2- Appletl builds proactive commands OPEN 
CHANNEL with InitQ method in order to open a 
channel. 

ProactiveHandler.sendQ method is called. 




2- OPEN CHANNEL 
proactive command is 
fetched 

TERMINAL RESPONSE is 
issued with channel status 
value = 0x8100 


1 


Channel status TLV is not present 

1- Send envelope unrecognized 

2- Call 

USATEnvelopeHandler.getChannelStatus{0x01) 
method. 


2- UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




2 


Channel status TLV with the identifier is not 
present 

1 - Send envelope Event Download Channel 
Status with Channel status Value = 0x8100 

2- Call 

USATEnvelopeHandler.getChannelStatus{0x02) 

method. 


2- UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




3 


Channel status TLV with a length equal to 

1- Send envelope unrecognized with Channel 
status TLV with a length equal to 0. 

2- Call 

USATEnvelopeHandler.getChannelStatus(OxOI) 
method. 


2- UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




4 


Channel status TLV with a length equal to 1 

1- - Send envelope unrecognized with Channel 
status TLV with a length equal to 1 . 

2- Call 

USATEnvelopeHandler.getChannelStatus(OxOI) 
method. 


2- OUT_OF_TLV_BOUNDARIES 
ToolkitException is thrown 




5 


Get channel status value 

1- Send envelope Event Download Channel 
Status with Channel status value=0x8100. 

2- Call 

USATEnvelopeHandler.getChannelStatus{0x01) 
method. 


2- Returns 0x8100 




6 


Get channel status value with 2 TLV 

1- Send envelope Event Download Channel 
Status with 2 channel status value: 0x81 00 and 
0x8101. 

2- Call 

USATEnvelopeHandler.getChannelStatus(OxOI) 
method. 


2- Returns 0x8100 




7 


Get channel status value with 2 TLV 

1- Send envelope Event Download Channel 
Status with 2 channel status value: 0x81 00 and 
0x8201 . 
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2- Call 

USATEnvelopeHandler.getChannelStatus{0x02) 

method. 


2- Returns 0x8201 




8 


Channel status TLV is currently selected TLV 

1- Send envelope Event Download Channel 
Status with channel status value 0x8100. 

Call ViewHandler.FlndTLVQ method with Device 
Identity Tag. 

2- Call 

USATEnvelopeHandler.getChannelStatus{0x01) 
method. 

3- Compare 

USATEnvelopeHandler.getChannelStatus{0x01) 
and ViewHandler.getValueShort(O) method 
results. 


2- Returns 0x8100 

3- Check getChannelStatus{) 
=getValueShort{0) 




9 


Get channel status value after a proactive 
command 

1- Send envelope Event Download Channel 
Status with Channel status value=0x8100. 

2- Call 

USATEnvelopeHandler.getChannelStatus{0x01) 
method. 

3- Send a proactive command display text 

4- Call 

USATEnvelopeHandler.getChannelStatus(OxOI) 
method. 


2- Returns 0x8100 
4- Returns 0x8100 


3- DISPLAY TEXT proactive 
command is fetched 

TERMINAL RESPONSE is 
issued 



5.2.2.10 Method getSize 

Test Area Reference: Api_2_Ueh_Gtsz 

5.2.2.10.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getSize() 

5.2.2.10.1.1 Normal execution 

• CRRNl: Returns the BER TLV size, this includes the tag and the length. 

5.2.2.10.1.2 Parameter errors 
No requirements 

5.2.2.10.1.3 Context errors 
No requirements 

5.2.2.10.2 Test area files 
Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Gtsz.java 
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Api_2_Ueh_Gtsz_ 1 .j ava 
Api_2_Ueh_Gtsz.cap 

Test coverage 



38 



ETSI TS 131 213 V6.0.0 (2007-03) 



CRR number 


Test case number 


1 


1,2 



5.2.2.10.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 





Send an unrecognized envelope of length 
0x33 (including tag and length) 






1 


Call getSizeO method just after 
triggering of the application. 


Returns 0x33 




2 


Call getSizeO method after a proactive 
command. 


Returns 0x33 





5.2.2.11 Method getTag 

Test Area Reference: Api_2_Ueh_Gttg 

5.2.2.1 1 .1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getTag () 

5.2.2.11.1.1 Normal execution 

• CRRN 1 : Returns the BER Tag of the BER TLV Hst. 

5.2.2.11.1.2 Parameter errors 
No requirements. 

5.2.2.11.1.3 Context errors 
No requirements. 

5.2.2.11.2 Test area files 
Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Gttg.java 

Test Applet: Api_2_Ueh_Gttg_l.java 

Cap File: Api_2_Ueh_Gttg.cap 



5.2.2.11.3 



Test coverage 



CRR number 


Test case number 


1 


1,2 
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5.2.2.11.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 





Send an unrecognized envelope 






1 


Call getTagO method just after 
triggering of the application. 


Returns 0x01 




2 


Call getTagO method after a proactive 
command. 


Returns 0x01 





5.2.2.12 Method compareValue 

Test Area Reference: Api_2_Ueh_Cprv 

5.2.2.12.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte compareValue (short valueOffset, 

byte[] compareBuf f er, 
short compareOf f set, 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

5.2.2.12.1.1 Normal execution 
Compares the last found TLV element with a buffer: 

• CRRN 1 : returns if identical. 

• CRRN2: returns -1 if the first miscomparing byte in Comprehension TLV List is less than that in compareBuffer. 

• CRRN3: returns 1 if the first miscomparing byte in Comprehension TLV List is greater than that in 
compareBuffer. 

5.2.2.12.1.2 Parameter errors 

• CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

• CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if 
compareLength is negative ArraylndexOutOfBoundsException shall be thrown. 

• CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException.OUT_OF_TLV_BOUND ARIES. 



5.2.2.12.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

• CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException. UN A VAILABLE_ELEMENT. 

5.2.2.12.2 Test area files 

Specific triggering: Unrecognized Envelope 
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Test Source: 
Test Applet: 
Cap File: 

5.2.2.12.3 



Test_Api_2_Ueh_Cprv.j ava 
Api_2_Ueh_Cprv_ 1 .j ava 
Api_2_Ueh_Cprv . c ap 

Test coverage 



CRR number 


Test case number 


N1 


12, 15 


N2 


13, 16, 18 


N3 


14, 17 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


C1 


Does not apply for 
USATEnvelopeHandler 


C2 


11 



5.2.2.12.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Search TLV 02h 








compareValue with a null compareBuffer 


NullPointerException is thrown 




2 


Search TLV OBh 








compareOffset > compareBuffer.length 

compareValue ( ) 
compareBuffer.length = 5 
compareOffset = 5 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


compareOffset < 

compareValue ( ) 
compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareValue () 
compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareValue ( ) 
compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareValue ( ) 
compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


Array 1 ndexOutOfBou ndsExceptio 
n is thrown 




7 


Search TLV 06h 








valueOffset > TLV Length 

compareValue () 
valueOffset = 6 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

compareValue () 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




compareLength = 1 






9 


compareLength > TLV length 

compareValue () 
valueOffset = 
compareBuff er . length = 15 
compareOf f set = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > TLV length 

compareValue () 
valueOffset = 2 
compareBuff er . length = 15 
compareOf f set = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Search TLV 01 h 


Result is TLV NOT FOUND 






compareValue () 


ToolkitException. UNAVAILABLE 
ELEIVIENT is thrown 




12 


Search TLV 06h 








Initialize compareBuffer 

compareBuf fer = 
81 11 22 33 44 F5 








Compare buffers 

compareValue ( ) 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result is OOh 




13 


Initialize compareBuffer 

compareBuffer = 
7F 11 22 33 44 F5 








Compare buffers with same parameters 


Result is -1 




14 


Initialize compareBuffer 

compareBuffer = 
83 11 22 33 44 F5 








Compare buffers with same parameters 


Result is -1 




15 


Initialize compareBuffer 

compareBuffer = 

55 55 55 81 11 22 33 44 F5 

55 55 55 55 55 








Compare buffers 

compareValue () 
valueOffset = 1 
compareOf f set = 4 
compareLength = 5 


Result is OOh 




16 


Initialize compareBuffer 

compareBuffer = 

55 55 55 81 10 22 33 44 F5 

55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




17 


Initialize compareBuffer 

compareBuffer = 

55 55 55 81 12 22 33 44 F5 

55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




18 


Successful call, compareValue() with length=o 

CompareBuf fer . length = 15 
CompareOf f set = 15 
CompareLength = 


Result of compareValueO is 





5.2.2.13 Method copy 

Test Area Reference: Api_2_Ueh_Copy 

5.2.2.13.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short copy (byte [] dstBuffer, 
short dstOffset, 
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short dstLength) 
throws Java . lang.NullPointerException, 

Java . lang. ArraylndexOutOfBoundsException, 
Toolkit Except ion 

5.2.2.13.1.1 Normal execution 

• CRRNl: copies the Comprehension TLV list contained in the handler to the destination byte array. 

• CRRN2: returns dstOffset + dstLength. 

5.2.2.13.1.2 Parameter errors 

• CRRPl: if dstBuffer is null a NullPointerException is thrown. 

• CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative, 
an ArraylndexOutOfBoundsException is thrown. 

• CRRP3: if dstLength is greater than the length of the Comprehension TLV List, an instance of ToolkitException 
shall be thrown. The reason code shall be ToolkitException. OUT_OF_TLV_BOUND ARIES. 



5.2.2.13.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.13.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Copy.java 

Test Applet: Api_2_Ueh_Copy_Ljava 

Cap File: Api_2_Ueh_Copy.cap 



5.2.2.13.3 



Test coverage 



CRR number 


Test case number 


N1 


9, 11, 13, 15 


N2 


8, 10, 12, 14, 16 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7 


CI 


Does not apply for 
USATEnvelopeHandler 



5.2.2.13.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


NULL as parameter to dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

copy 

dstBuffer.length = 5 
dstOffset = 5 
dstLength = 1 


ArraylndexOutOfBoundsException is 
thrown 




3 


dstOffset < 

copy {) 


ArraylndexOutOfBoundsException is 
thrown 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




dstBuffer . length = 5 
dstOffset = -1 
dstLength = 1 






4 


dstLength > dstBuffer.length 

copy 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsException is 
thrown 




5 


DstOffset + dstLength > dstBuffer.length 

copy {) 

DstBuffer.length = 5 
DstOffset = 3 
DstLength = 3 


ArraylndexOutOfBoundsException is 
tlirown 




6 


dstLength < 

copy 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsException is 
thrown 




7 


DstLength > length of the Comprehension 
TLV list 

copy 

DstBuffer.length = 48 
DstOffset = 
DstLength = 48 


Tooll<itException.OUT OF TLV BO 
UNDARIES is thrown 




8 


Successful call, dstBuffer is the whole buffer 

copy 

DstBuffer.length = 47 
DstOffset = 
DstLength = 47 


Result of copyO is 0X0047 




9 


Compare the buffer 


Result of arrayCompareO is 




10 


Successful call, dstBuffer is part of a buffer 

copy 

DstBuffer.length = 50 
dstOffset = 3 
dstLength = 47 


Result of copyO is 0X0032 




11 


Compare the whole buffer 


Result of arrayCompareO is 




12 


Successful call, dstBuffer is part of a buffer 

copy 

dstBuffer.length = 15 
dstOffset = 3 
dstLength = 6 


Result of copyO is 0X0009 




13 


Compare the whole buffer 


Result of arrayCompareO is 




14 


Successful call, dstBuffer is part of a buffer 

copy 

dstBuffer.length = 260 
dstOffset = 257 
dstLength = 3 


Result of copyO is 0X01 04 




15 


Compare the whole buffer 


Result of arrayCompareO is 




16 


Successful call, copy() with length =0 

dstBuffer.length = 260 
dstOffset = 260 
dstLength = 


Result of copyO is 0x104 





5.2.2.14 Method copyValue 

Test Area Reference: Api_2_Ueh_Cpyv 



5.2.2.14.1 



Conformance requirement 



The method with following header shall be compliant with its definition in the API. 

public short copyValue (short valueOffset, 

byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang .ArraylndexOutOfBoundsException, 
ToolkitException 
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5.2.2.14.1.1 Normal execution 

• CRRNl: copies a part of the last TLV element which has been found, into a destination, buffer. 

• CRRN2: returns dstOffset + dstLength. 

5.2.2.14.1.2 Parameter errors 

• CRRP 1 : if dstBuffer is null NullPointerException is thrown. 

• CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException is thrown. 

• CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 



5.2.2.14.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

• CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException.UNAVAILABLE_ELEMENT. 

5.2.2.14.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Cpyv.java 

Test Applet: Api_2_Ueh_Cpyv_Ljava 

Cap File: Api_2_Ueh_Cpyv.cap 



5.2.2.14.3 



Test coverage 



5.2.2.14.4 



CRR number 


Test case number 


N1 


13,15 


N2 


12, 14, 16 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


C1 


Does not apply for 
USATEnvelopeHandler 


C2 


11 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Search TLV 02h 








copyValue with a null dstBuffer 


NullPointerException is thrown 




2 


Search TLV OBh 








dstOffset > dstBuffer.length 

copyValue () 
dstBuffer.length = 5 
dstOffset = 5 
dstLength = 1 


Array 1 ndexOutOfBou ndsExceptio 
n is thrown 




3 


dstOffset < 

copyValue () 
dstBuffer.length = 5 

dstOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




dstLength = 1 






4 


dstLength >dstBuffer.length 

copyValue () 
dstBuffer .length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

copyValue () 
dstBuffer. length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

copyValue () 
dstBuffer. length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Search TLV 06h 








valueOffset > TLV Length 

copyValue () 
valueOffset = 6 
dstBuffer. length = 15 
dstOffset = 
dstLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

copyValue () 
valueOffset = -1 
dstBuffer. length = 15 
dstOffset = 
dstLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > TLV length 

copyValue ( ) 
valueOffset = 
dstBuffer. length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > TLV length 

copyValue ( ) 
valueOffset = 2 
dstBuffer. length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Search TLV 01 h 








copyValue () 


ToolkitException. UNAVAILABLE 

ELEIVIENT is thrown on the 
copyValueO method call. 




12 


Search TLV 06h 








Successful call 

copyValue () 
valueOffset = 
dstBuffer. length = 6 
dstOffset = 
dstLength = 6 


Result of copyValueO is 0x0006 




13 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result is OOh 




14 


initialize dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

copyValue () 
valueOffset = 1 
dstBuffer. length = 20 
dstOffset = 3 
dstLength = 4 


Result of copyValueO is 0x0007 




15 


Compare buffer 

buffer = 
55 55 55 11 22 
33 44 55 55 55 
55 55 55 55 55 
55 55 55 55 55 


Result is OOh 




16 


Successful call, copy with length =0 

dstBuffer. length = 20 
dstOffset = 20 
dstLength = 


Result of copyValueO is 20 
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5.2.2.15 Method findAndCompareValue(byte tag, byteQ compareBuffer, short 
compareOffset) 

Test Area Reference: Api_2_Ueh_Facrb_Bs 

5.2.2.15.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte[] compareBuffer, 
short compareOffset) 
throws Java . lang. NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

5.2.2.15.1.1 Normal execution 

Looks for the first occurrence of a TLV element from beginning of a TLV list and compare its value with a buffer: 

• CRRNl : if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current 
TLV is no longer defined. 

• CRRN2: if the method is successful then the corresponding TLV becomes current. 

• CRRN3: if identical returns 0. 

• CRRN4: if the first miscomparing byte in Comprehension TLV is less than that in compareBuffer returns -1. 

• CRRN5: if the first miscomparing byte in Comprehension TLV is greater than that in compareBuffer returns 1 . 

• CRRN6: The search method is comprehension required flag independent. 

5.2.2.15.1.2 Parameter errors 

• CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

• CRRP2: if compareOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 

5.2.2.15.1.3 Context errors 

• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.15.2 Test area files 
Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Facrb_Bs.java 

Test Applet: Api_2_Ueh_Facrb_Bs_l.java 

Cap File: Api_2_Ueh_Facrb_Bs.cap 



5.2.2.15.3 Test coverage 



CRR number 


Test case number 


N1 


6,7 


N2 


9 
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N3 


8, 12, 13 


N4 


10, 14 


N5 


11, 15 


N6 


16, 17 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 
USATEnvelopeHandler 



5.2.2.15.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized Envelope with TLV: Tag 

02, Value 83 81, Tag 06, Value 81 11 22 33 44 

F5, Tag 02 Value 22 44 Tag 33, Length C4 

Value 01 02... 






1 


findAndCompareValueO with a null dstBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

f indAndCompareValue () 
tag = 06h 

compareBuffer.length = 12 
compareOffset = 12 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


compareOffset < 

f IndAndCompareValue () 
compareBuffer.length = 12 
compareOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > compareBuffer.length 

f IndAndCompareValue () 
compareBuffer.length = 05 
compareOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + length > 
compareBuffer.length 

f IndAndCompareValue () 
compareBuffer.length = 12 
compareOffset = 7 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


Select a TLV (tag 02h) 








findAndCompareValueO 

tag = 03h 


Tooll<itException. UNAVAILABLE 
ELEIVIENT is thrown 




7 


Call the getValueLengthO method 


Tooll<itException. UNAVAILABLE 
ELEIVIENT is thrown. 




8 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F5 








Compare buffers 

f IndAndCompareValue () 
tag = 06h 
compareOffset = 


Result is OOh 




9 


Verify current TLV 

getValueLength ( ) 


Result is 06 




10 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F4 








Compare buffers with same parameters 


Result is +1 




11 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F6 








Compare buffers with same parameters 


Result is -1 




12 


Initialize compareBuffer 

compareBuffer = 

55 55 81 11 22 33 44 F5 55 55 55 55 








Compare buffers 

f IndAndCompareValue {) 
compareOffset = 2 


Result is OOh 




13 


Initialize compareBuffer 

compareBuffer = 

55 55 83 81 55 55 55 55 55 55 55 55 








Compare buffers 

f IndAndCompareValue () 
compareOffset = 2 


Result is OOh 
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14 


Initialize compareBuffer 

compareBuf fer = 

55 55 83 80 55 55 55 55 55 55 55 55 








Compare buffers 

f indAndCompareValue () 
compareOf f set = 2 


Result is +1 




15 


Initialize compareBuffer 

compareBuffer = 

55 55 83 82 55 55 55 55 55 55 55 55 








Compare buffers 

f IndAndCompareValue () 
compareOf f set = 2 


Result is -1 




16 


Initialize compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








Successful call (with tag 02h) 

f IndAndCompareValue () 
tag = 02h 

compareBuf fer . length = 12 
compareOf f set = 


Result is OOh 




17 


Initialize compareBuffer 

CompareBuffer = 01 02 ... C4 








Successful call (with tag B3h) 

f IndAndCompareValue () 
Tag = B3h 

CompareBuf fer . length = C4 
CompareOf f set = 


Result is OOh 





5.2.2.1 6 Method findAndCompareValue(byte tag, byte occurrence, short valueOffset, 
byteQ compareBuffer, short compareOffset, short compareLength) 

Test Area Reference: Api_2_Ueh_Facrbbs_Bss 

5.2.2.16.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte occurrence, 
short valueOffset, 
byte[l compareBuffer, 
short compareOffset, 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 



5.2.2.16.1.1 



Normal execution 



Looks for the indicated occurrence of a TLV element from the beginning of a TLV list and compare its value with a 
buffer: 

• CRRNl : if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current 
TLV is no longer defined. 

• CRRN2: if the method is successful then the corresponding TLV becomes current. 

• CRRN3: if identical is returned. 

• CRRN4: if the first miscomparing byte in Comprehension TLV is less than that in compareBuffer -1 is returned. 

• CRRN5: if the first miscomparing byte in Comprehension TLV is greater than that in compareBuffer 1 is 
returned 

• CRRN6: The search method is comprehension required flag independent. 



£75/ 



3GPP TS 31.213 version 6.0.0 Release 6 



49 



ETSI TS 131 213 V6.0.0 (2007-03) 



5.2.2.16.1.2 Parameter errors 

• CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

• CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if 
compareLength is negative ArraylndexOutOfBoundsException shall be thrown. 

• CRRP3: if valueOffset, compareLength or both are out of the current TLV an instance of ToolkitException shall 
be thrown. The reason code shall be ToolkitException.OUT_OF_TLV_BOUND ARIES. 

• CRRP4: if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException.BAD_INPUT_PARAMETER. 



5.2.2.16.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.16.2 Test area files 
Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Facrbbs_Bss.java 

Test Applet: Api_2_Ueh_Facrbbs_Bss_l.java 

Cap File: Api_2_Ueh_Facrbbs_Bss.cap 

5.2.2.16.3 Test coverage 



CRR number 


Test case number 


N1 


12, 13 


N2 


15 


N3 


14, 18,21,22,26 


N4 


16,20 


N5 


17, 19,23 


N6 


24,25 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


P4 


11 


C1 


Does not apply for 
USATEnvelopeHandler 



5.2.2.16.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized Envelope with TLV: Tag 

02, Value 83 81 , Tag 06, Value 81 1 1 22 33 44 

F5, Tag 02 Value 22 44 Tag 33, Length C4 

Value 01 02... 






1 


fIndAndCompareValueO with a null 
compareBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

f indAndCompareValue () 
tag = 06h, occurrence = 1 
valueOffset = 
compareBuffer.length = 6 
compareOffset = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




compareLength = 1 






3 


compareOffset < 

f inciAnciCompareValue () 
compareBuffer . length = 6 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

f InciAndCompareValue () 
compareBuffer . length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

f IndAndCompareValue () 
compareBuff er . length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

f IndAndCompareValue {) 
compareBuff er . length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Value Length 

f IndAndCompareValue () 
tag = 06h, occurrence = 1 
valueOffset = 6 
compareBuffer . length = 15 
compareOffset = 
compareLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

f IndAndCompareValue ( ) 
valueOffset = -1 
compareBuffer . length = 15 
compareOffset = 
compareLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Value length 

f IndAndCompareValue {) 
valueOffset = 
compareBuffer . length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Value length 

f IndAndCompareValue () 
valueOffset = 2 
compareBuffer . length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Invalid parameter 

f IndAndCompareValue {) 
occurrence = 


ToolkitException.BAD INPUT P 
ARAIVIETER is thrown 




12 


Select a TLV (tag 02h) 








findAndCompareValueQ 

tag = 06h 
occurrence = 2 


ToolkitException. UNAVAILABLE 
_ELEI\/IENT is thrown 




13 


Call the getValueLengthO method 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown. 




14 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F5 








findAndCompareValueQ 

tag = 06h, occurrence = 1 
valueOffset = 
compareOffset = 
compareLength = 6 


Result is OOh 




15 


Verify current TLV 

getValueLength ( ) 


Result is 0006 




16 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F4 








Compare buffers with same parameters 


Result is +1 




17 


Initialize compareBuffer 

compareBuffer = 81 11 22 33 44 F6 








Compare buffers with same parameters 


Result is -1 




18 


Initialize compareBuffer 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




compareBuff er = 

55 55 55 22 33 44 F5 55 55 55 55 








Compare buffers 

f IndAndCompareValue () 
valueOffset = 2 
compareOf f set = 3 
compareLength = 4 


Result is OOh 




19 


Initialize compareBuffer 

compareBuf fer = 

55 55 55 22 33 45 F5 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




20 


Initialize compareBuffer 

compareBuffer = 

55 55 55 22 33 43 F5 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




21 


Initialize compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueO 

tag = 02h, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is OOh 




22 


Initialize compareBuffer 

compareBuffer = 

22 44 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueO 

tag = 02h, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is OOh 




23 


Initialize compareBuffer 

compareBuffer = 

22 45 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueO 

tag = 02h, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is -1 




24 


Initialize compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








Successful call (with tag 02h) 

f IndAndCompareValue () 
tag = 02h, occurrence = 1 
valueOffset = 
compareBuf fer . length = 12 
compareOf f set = 
compareLength = 2 


Result is OOh 




25 


Initialize compareBuffer 

compareBuffer = 01 02 ... C4 








Successful call (with tag B3h) 

f IndAndCompareValue () 
tag = B3h, occurrence = 1 
valueOffset = 
compareBuf fer . length = 00C4 
compareOf f set = 
compareLength = 00C4 


Result is OOh 




26 


Successful call, findAndCompareValueO with 
length =0 

DstBuf fer .length = C4 
DstOffset = C4 
DstLength = 


Result of findAndCompareValueO 
is OOh 





5.2.2.17 Method findAndCopyValue(byte tag, byte[] dstBuffer, short dstOffset) 

Test Area Reference: Api_2_Ueh_Facyb_Bs 
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5.2.2.17.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte[] dstBuffer, 
short dstOffset) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 



5.2.2.17.1.1 



Normal execution 



• CRRNl: looks for the first occurrence of a TLV element from the beginning of a TLV list and copy its value into 
a destination buffer. 

• CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current 
TLV is no longer defined. 

• CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + length of the 
copied value is returned. 

• CRRN4: The search method is comprehension required flag independent. 

5.2.2.17.1.2 Parameter errors 

• CRRP 1 : if dstBuffer is null NullPointerException shall be thrown. 

• CRRP2: if dstOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 



5.2.2.17.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.17.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Facyb_Bs.java 

Test Applet: Api_2_Ueh_Facyb_Bs_l.java 

Cap File: Api_2_Ueh_Facyb_Bs.cap 



5.2.2.17.3 



Test coverage 



CRR number 


Test case number 


N1 


9, 11, 13 


N2 


6,7 


N3 


8, 10, 12 


N4 


14, 15, 16, 17 


P1 


1 


P2 


2, 3, 4, 5 


C1 


Does not apply for 
USATEnvelopeHandler 
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5.2.2.17.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized Envelope with TLV: Tag 

02, Value 83 81 , Tag 06, Value 81 1 1 22 33 44 

F5, Tag 02 Value 22 44 Tag 33, Length C4 

Value 01 02... 






1 


FindAndCopyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

f indAndCopyValue () 
tag = 06h 

dstBuffer.length = 06 
dstOffset = 06 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

f IndAndCopyValue () 
dstBuffer.length = 06 
dstOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > dstBuffer.length 

f indAndCopyValue () 
dstBuffer.length = 05 
dstOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


DstOffset + length >dstBuffer.length 

f IndAndCopyValue () 
DstBuffer.length = 06 

DstOffset = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


Select a TLV (tag 02h) 








findAndCopyValueO 

tag = 03h 


Tooll<itException. UNAVAILABLE 
ELEMENT is thrown 




7 


Call the getValueLengthO method 


Tooll<itException. UNAVAILABLE 
ELEIVIENT is thrown. 




8 


Successful call 

f IndAndCopyValue () 
Tag = 06h 

DstBuffer.length = 06 
DstOffset = 


Result of findAndCopyValue () is 
0006 




9 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result is OOh 




10 


Initialize dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

f IndAndCopyValue () 
dstBuffer.length = 12 
dstOffset = 2 


Result of findAndCopyValue () is 
0008 




11 


Compare buffer 

buffer = 

55 55 81 11 22 33 44 F5 55 55 55 55 


Result is OOh 




12 


Successful call 

f IndAndCopyValue () 
tag = 02h 

dstBuffer.length = 2 
dstOffset = 


Result of findAndCopyValue () is 
0002 




13 


Compare buffer 

buffer = 83 81 


Result is OOh 




14 


Successful call (with tag 82h) 

f IndAndCopyValue () 
tag = 82h 

dstBuffer.length = 02 
dstOffset = 


Result of findAndCopyValue () is 
0002 




15 


Compare buffer 

buffer = 83 81 


Result is OOh 




16 


Successful call (with tag B3h) 

f IndAndCopyValue () 
tag = B3h 

dstBuffer.length = C4 
dstOffset = 


Result of findAndCopyValue () is 
00C4 




17 


Compare buffer 

buffer = 01 02 ... C4 


Result is OOh 
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5.2.2.18 Method findAndCopyValue(byte tag, byte occurrence, short valueOffset, 
byte[] dstBuffer, short dstOffset, short dstLength) 

Test Area Reference: Api_2_Ueh_Facybbs_Bss 

5.2.2.18.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte occurrence, 
short valueOffset, 
byte[l dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

5.2.2.18.1.1 Normal execution 

• CRRNl: looks for the indicated occurrence of a TLV element from the beginning of a TLV list and copy its 
value into a destination buffer. 

• CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current 
TLV is no longer defined. 

• CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + dstLength is 
returned. 

• CRRN4: The search method is comprehension required flag independent. 

5.2.2.18.1.2 Parameter errors 

• CRRP 1 : if dstBuffer is null NullPointerException shall be thrown. 

• CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException shall be thrown. 

• CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException.OUT_OF_TLV_BOUNDARIES. 

5.2.2.18.1.3 Context errors 

• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.18.2 Test area files 
Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Facybbs_Bss.java 

Test Applet: Api_2_Ueh_Facybbs_Bss_l.java 

Cap File: Api_2_Ueh_Facybbs_Bss.cap 



5.2.2.18.3 Test coverage 



CRR number Test case number 
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N1 


14, 15, 17, 19,20 


N2 


11, 12 


N3 


13, 15, 17, 19,25 


N4 


21,22, 23,24 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


CI 


Does not apply for 
USATEnvelopeHandler 



5.2.2.18.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized Envelope with TLV: Tag 

02, Value 83 81 , Tag 06, Value 81 1 1 22 33 44 

F5, Tag 02 Value 22 44 Tag 33, Length C4 

Value 01 02... 






1 


findAndCopyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

f indAndCopyValue () 

tag = 06h, occurrence = 1 

valueOffset = 

dstBuffer.length = 5 

dstOffset = 5 

dstLength = 1 


Array 1 ndexOutOfBou ndsExceptio 
n is thrown 




3 


dstOffset < 

f IndAndCopyValue () 
dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength >dstBuffer.length 

f IndAndCopyValue () 
dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

f IndAndCopyValue () 
dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


Array 1 ndexOutOfBou ndsExceptio 
n is thrown 




6 


dstLength < 

f IndAndCopyValue () 
dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Value Length 

f IndAndCopyValue () 

tag = 06h, occurrence = 1 

valueOffset = 6 

dstBuffer.length = 15 

dstOffset = 

dstLength = 1 


Tooll<itException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

f IndAndCopyValue () 
valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Value length 

f IndAndCopyValue () 
valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

f IndAndCopyValue () 
valueOffset = 2 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




dstBuffer .length = 15 
dstOffset = 
dstLength = 5 






11 


Select a TLV (tag 02h) 








findAndCopyValueO 

tag = 06h 
occurrence = 2 


ToolkitException. UNAVAILABLE 
_ELEMENT is thrown 




12 


Call the getValueLengthO method 


ToolkitException. UNAVAILABLE 
ELEIVIENT is thrown. 




13 


Successful call 

f IndAndCopyValue () 

tag = 06h, occurrence = 1 

valueOffset = 

dstBuffer .length = 06 

dstOffset = 

dstLength = 06 


Result of findAndCopyValueQ is 
6 




14 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result is OOh 




15 


Initialize dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

f IndAndCopyValue () 

tag = 06h, occurrence = 1 

valueOffset = 2 

dstBuffer .length = 12 

dstOffset = 3 

dstLength = 04 


Result of findAndCopyValue () is 
0007 




16 


Compare buffer 

buffer = 

55 55 55 22 33 44 F5 55 55 55 55 55 


Result is OOh 




17 


Successful call 

f IndAndCopyValue () 

tag = 02h, occurrence = 1 

valueOffset = 

dstBuffer .length = 12 

dstOffset = 

dstLength = 2 


Result of findAndCopyValueQ is 
0002 




18 


Compare buffer 

buffer = 83 81 55 ... 55 


Result is OOh 




19 


Successful call 

f IndAndCopyValue () 

tag = 02h, occurrence = 2 

valueOffset = 

dstBuffer. length = 12 

dstOffset = 

dstLength = 2 


Result of findAndCopyValueQ is 
0002 




20 


Compare buffer 

buffer = 22 44 55 ... 55 


Result is OOh 




21 


Successful call (with tag 82h) 

f IndAndCopyValue () 
tag = 82h 
occurrence = 1 
valueOffset = 
dstBuffer. length = 12 
dstOffset = 
dstLength = 02 


Result of findAndCopyValue () is 
0002 




22 


Compare buffer 

buffer = 83 81 55 ... 55 


Result is OOh 




23 


Successful call (with tag 82h) 

f IndAndCopyValue {) 
tag = 82h 
occurrence = 2 
valueOffset = 
dstBuffer .length = 12 
dstOffset = 
dstLength = 02 


Result of findAndCopyValue {) is 
0002 




24 


Compare buffer 

Buffer = 22 44 55 ... 55 


Result is OOh 




25 


Successful call, findAndCopyValueQ with 
length =0 

DstBuffer .length = 12 
dstOffset = 12 


Result of findAndCopyValue () is 
12 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




dstLength = 







5.2.2.19 Method findTLV 

Test Area Reference: Api_2_Ueh_Find 

5.2.2.19.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte findTLV (byte tag, 

byte occurrence) 
throws ToolkitException 

5.2.2.19.1.1 Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of the TLV list (handler buffer): 

• CRRNl: the method is successful if the required occurrence exists then the corresponding TLV becomes current. 

• CRRN2: if the method is successful then it returns TLV_FOUND_CR_SET when Comprehension Required flag 

is set. 

• CRRN3: if the method is successful then it returns TLV_FOUND_CR_NOT_SET when Comprehension 
Required flag is not set. 

• CRRN4: if the required occurrence of the TLV element does not exist, the current TLV is no longer defined and 
TLV_NOT_FOUND is returned. 

• CRRN5: The search method is comprehension required flag independent. 

5.2.2.19.1 .2 Parameter errors 

• CRRP 1 : if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException.BAD_INPUT_PARAMETER. 



5.2.2.19.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.19.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Find.java 

Test Applet: Api_2_Ueh_Find_l.java 

Cap File: Api_2_Ueh_Find.cap 



5.2.2.19.3 



Test coverage 



CRR number 


Test case number 


N1 


3,5 


N2 


2,4 


N3 


10, 11 


N4 


6, 7, 8, 9 


N5 


12, 13 
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PI 


1 


CI 


Does not apply for 
USATEnvelopeHandler 



5.2.2.19.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Trigger the applet with Unrecognized Envelope 

including: 

Tag 82, tag 86, tag 8B, tag 02 and tag 04 






1 


Invalid input parameter 

findTLVO 
Occurrence = 


ToolkitExceptlon.BAD INPUT P 
ARAIVIETER is thrown 




2 


Search 1 St TLV 

findTLVO 
Tag = 02h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




3 


Call the getValueLengthO method 


Result is 0x02 




4 


Search 2nd TLV 

findTLVO 
Tag = 06h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




5 


Call the getValueLengthO method 


Result is 0x05h 




6 


Select a TLV (tag 02h) 








Search a wrong tag 

findTLVO 
Tag = 03h 
Occurrence = 1 


Result is TLV_NOT_FOUND 




7 


Call the getValueLengthO method 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown. 




8 


Search a tag with wrong occurrence 

findTLVO 
Tag = 02h 
Occurrence = 3 


Result is TLV_NOT_FOUND 




9 


Call the getValueLengthO method 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown. 




10 


Search the TLV 

findTLVO 
Tag = 02h 
Occurrence = 2 


Result is 
TLV_FOUND_CR_NOT_SET 




11 


Search the TLV 

findTLVO 
Tag = 04h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




12 


Search tag 86h 

findTLVO 
Tag = 86h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




13 


Search tag 84h 

findTLVO 
Tag = 84h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 





5.2.2.20 Method getCapacity 

Test Area Reference: Api_2_Ueh_Gcap 

5.2.2.20.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getCapacity ( ) 
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5.2.2.20.1.1 Normal execution 

• CRRNl: The method shall return the maximum size of the Comprehension TLV list managed by the handler. 



5.2.2.20.1.2 
No requirements 

5.2.2.20.1.3 
No requirements 

5.2.2.20.2 

Test Source: 
Test Applet: 
Cap File: 

5.2.2.20.3 



Parameter Errors 

Context errors 

Test area files 

Test_Api_2_Ueh_Gcap.j ava 
Api_2_Ueh_Gcap_ 1 .j ava 
Api_2_Ueh_Gcap.cap 

Test coverage 



CRR number 


Test case number 


N1 


1 



5.2.2.20.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


USATEnvelopeHandler available 

1 - Send envelope Menu Selection 

2 - The applet calls the getLength{) method 

3 - The applet calls the getCapacityO method 


1 - Applet is triggered 

2 - No exception is thrown 

3 - No exception is thrown; the 
capacity is greater than the BER 
TLV Length 





5.2.2.21 Method getLength 

Test Area Reference: Api_2_Ueh_Glen 

5.2.2.21.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getLength () 

throws ToolkitException 

5.2.2.21.1.1 Normal execution 

• CRRN 1 : returns the length in bytes of the TLV list. 

5.2.2.21 .1 .2 Parameter Errors 
No requirements. 
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5.2.2.21.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

5.2.2.21.2 Test area files 

Specific triggering: Unrecognized envelope 

Test Source: Test_Api_2_Ueh_Glen.java 

Test Applet: Api_2_Ueh_Glen_l.java 

Cap File: Api_2_Ueh_Glen.cap 



5.2.2.21.3 



Test coverage 



CRR number 


Test case number 


N1 


1,2,3,4 


CI 


Does not apply for 
USATEnvelopeHandler 



5.2.2.21.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Send an Unrecognized Envelope with BER lengtli of 
0x31 


Result of getLengthO is 0x0031 




2 


Send an Unrecognized Envelope with BER length of 
0x7F 


Result of getLengthO is 0x007Fh 




3 


Send an Unrecognized Envelope with BER length of 
81 80 


Result of getLengthO is 0x0080h 




4 


Send an Unrecognized Envelope with BER length of 
81 FC 


Result of getLengthO is OxOOFCh 





5.2.2.22 Method getValueByte 

Test Area Reference: Api_2_Ueh_Gvby 

5.2.2.22.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getValueByte (short valueOffset) 
throws ToolkitException 



5.2.2.22.1.1 



Normal execution 



CRRNl: Gets a byte from the last TLV element which has been found in the handler and returns its value 
(1 byte). 



5.2.2.22.1.2 



Parameter errors 



• CRRP 1 : if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason 
code shall be ToolkitException.OUT_OF_TLV_BOUND ARIES. 
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5.2.2.22.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

• CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException.UNAVAILABLE_ELEMENT. 

5.2.2.22.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Gvby.java 

Test Applet: Api_2_Ueh_Gvby_l.java 



Cap File: 
5.2.2.22.3 



Api_2_Ueh_Gvby.cap 
Test coverage 



CRR number 


Test case number 


N1 


3, 4, 5, 6, 7, 8 


P1 


2 


C1 


Does not apply for 
USATEnvelopeHandler 


C2 


1 



5.2.2.22.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized envelope with TLV: Tag 02, 
length 02, value 83 81 , Tag 06, length 06, Tag 
OB, length 21, Tag 33, Length C8 Value 01 02 ... 






1 


getValueByte{0) 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 02h 








getValueByte (2) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 02h 








getValueByte (1) 


Result is 0x81 




4 


Search TLV 02h (Device Identities TLV) 








getValueByte (0) 


Result is 83h (Source) 




5 


Search TLV 33h 








getValueByte (7E) 


Result is 0x7F 




6 


Search TLV 33h 








getValueByte (80) 


Result is 0x81 




7 


getValueByte (7F) 


Result is 0x80 




8 


Search TLV B3h 








getValueByte (C7) 


Result is 0xC8 





5.2.2.23 Method getValueLength 

Test Area Reference: Api_2_Ueh_Gvle 
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5.2.2.23.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueLength ( ) 

throws ToolkitException 



5.2.2.23.1.1 



Normal execution 



• CRRNl : gets and returns the binary length of the value field for the last TLV element which has been found in 
the handler. 



5.2.2.23.1.2 
No requirements. 

5.2.2.23.1.3 



Parameter errors 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

• CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException.UNAVAILABLE_ELEMENT. 

5.2.2.23.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test source: Test_Api_2_Ueh_Gvle.java 

Test Applet: Api_2_Ueh_Gvle_l.java 

Cap File: Api_2_Ueh_Gvle.cap 



5.2.2.23.3 



Test coverage 



CRR number 


Test case number 


N1 


2,3,4 


C1 


Does not apply for 
USATEnvelopeHandler 


C2 


1 



5.2.2.23.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Fill the Unrecognized envelope with TLV: Tag 02, 
length 02, Tag 06, length 05, Tag OB, length 24, 
Tag 33, Length C8 






1 


getValueLengthO 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 02h 








getValueLength ( ) 


Result is 0X0002 




3 


Search TLV OBh 








getValueLength ( ) 


Result is 0X0024 




4 


Search TLV 33h 








getValueLength ( ) 


Result is 0X00C8 
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5.2.2.24 Method getValueShort 

Test Area Reference: Api_2_Ueh_Gvsh 

5.2.2.24.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueShort (short valueOffset) 
throws ToolkitException 



5.2.2.24.1.1 



Normal execution 



• CRRNl: Gets a short from the last TLV element which has been found in the handler and returns its value 
(1 short). 



5.2.2.24.1.2 



Parameter errors 



• CRRP 1 : if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason 
code shall be ToolkitException.OUT_OF_TLV_BOUND ARIES. 



5.2.2.24.1.3 



Context errors 



• CRRCl : if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

• CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException.UNAVAILABLE_ELEMENT. 

5.2.2.24.2 Test area files 

Specific triggering: Unrecognized Envelope 

Test Source: Test_Api_2_Ueh_Gvsh.java 

Test Applet: Api_2_Ueh_Gvsh_Ljava 

Cap File: Api_2_Ueh_Gvsh.cap 



5.2.2.24.3 



Test coverage 



CRR number 


Test case number 


N1 


3,4,5,6,7,8 


PI 


2 


CI 


Does not apply for 
USATEnvelopeHandler 


C2 


1 



5.2.2.24.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 
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Fill the Unrecognized envelope with TLVs : 
Tag 02, Length 02 Value 83 81 
Tag 06, Length 06 Value 81 11 22 33 44 F5 
Tag 33, Length C9 Value 01 02 ... 






1 


getValueShort (0) 


ToolkitException. UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 02h 








getValueShort (2) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 02h 








getValueShort (0) 


Result is 0x83 0x81 




4 


Search TLV 06h 








getValueShort (1) 


Result is 0x1 1 0x22 




5 


Search TLV 33h 








getValueShort (7E) 


Result is 0x7F 0x80 




6 


Search TLV 33h 








getValueShort (80) 


Result is 0x81 0x82 




7 


getValueShort (7F) 


Result is 0x80 0x81 




8 


Search TLV B3h 








getValueShort {C7) 


Result is 0xC8 0xC9 





5.2.3 Interface USATTerminalProfile 

The constants in Java are resolved at compilation time, therefore a runtime test is not useful. No test of constants will be 
performed 

5.2.4 Class USATEnvelopeHandlerSystem 
5.2.4.1 Method getTheHandler 

Test Area Reference: Api_2_Ues_Gthd 

5.2.4.1.1 Conformance requirements 

The method with following header shall be compliant to its definition in the API. 

public static USATEnvelopeHandler getTheHandler ( ) 

throws uicc. toolkit. ToolkitException 



5.2.4.1.1.1 



Normal execution 



• CRRN 1 : The method shall return the single system instance of the class implementing the 
USATEnvelopeHandler interface. 

• CRRN2: The USATEnvelopeHandler is a Temporary JCRE Entry Point Object (see Java Card 2.2.1 Runtime 
Environment (JCRE) Specification []) 

5.2.4.1.1.2 Parameter Errors 
No requirements. 

5.2.4.1.1.3 Context errors 

• CRRC 1 : The method shall throw ToolkitException.HANDLER_NOT_AVAILABLE if the handler is busy. 

5.2.4.1.2 Test area files 

Test Source: Test_Api_2_Ues_Gthd.java 

Test Applet: Api_2_Ues_Gthd_l.java 

Cap File: Api_2_Ues_Gthd.cap 
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5.2.4.1.3 



Test coverage 



CRR number 


Test case number 


N1 


1, 2, 3 


N2 


Tested in § 5.3.7.1 , other parts transferred to {U)SAT framework from 

API. 


C1 


Tested in § 5.3.1 .5, IVIinimum Handler Availability on 
USATEnvelopeHandler. 



5.2.4.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Call GetTheHandlerO method twice 


The returned objects shall be the 
same 




2 


Verify that getTheHandler() method returns an 
USATEnvelopeHandler 


The reference returned shall be an 

object implementing the 

USATEnvelopeHandler interface 

(check cast) 




3 


Verify the returned value is not null 


The reference returned shall not be 
null. 





5.2.5 Interface ToolkitRegistry 
5.2.5.1 Method clearEvent 

Test Area Reference: Api_2_Tkr_Cevt 

5.2.5.1.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void clearEvent (short event) 

throws ToolkitException, 

javacard. framework .TransactionException 

5.2.5.1.1.1 Normal execution 

• CRRNl: A call to isEventSet() method for a cleared event should return false after a call to clearEvent. 

• CRRN2: The (U)SAT Framework shall not trigger the applet on the occurrence of the cleared event anymore. 

• CRRN3: if event was EVENT_MO_SHORT_MESSAGE_CONTROL_B Y_SIM and after the call, no applet is 
registered to it, The (U)SAT Framework shall allow an applet to register to this event. 

• CRRN4: if event was EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM and one applet is still 
registered to this event. The (U)SAT Framework shall not allow an applet to register to this event. 



5.2.5.1.1.2 

No requirements. 

5.2.5.1.1.3 



Parameter Errors 



Context errors 



CRRCl: shall throw javacard. framework.TransactionException - if the operation would cause the commit 
capacity to be exceeded. 
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CRR number 


Test case number 


N1 


1 


N2 


2 


N3 


Framework 


N4 


Framework 


CI 


not testable 



5.2.5.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Clear ALLOWED events 

Install Applet registered to 
EVENT_FORMATTED_SMS_PP_ENV event 

For events (2 to 6, 10 and 24) defined In 
TS 31.130 [2] : 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

The applet calls: 

1- Call clearEventO method 

2- Call IsEventSetO method 


1 - No exception is thrown each 
time. 

2- Shall return false each time. 




2 


Checking applet isn't triggered by an 

ENVELOPE(EVENT_FORMATTED_SMS_PP_EN 

V) command 

1 - reset and Initialize the card 

2 - An 

ENVELOPE (EVENT_FORMATTED_SMS_PP_ENV) Is 
sent . 


Applet is not triggered by an 
ENVELOPE(EVENT FORMAI 1 bD 
_SMS_PP_ENV) command 





5.2.5.2 Method isEventSet 

Test Area Reference: Api_2_Tkr_Ievs 

5.2.5.2.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public boolean IsEventSet (short event) 



5.2.5.2.1.1 



Normal execution 
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• CRRNl : shall return true if the event is set in the Toolkit Registry for the applet. 

• CRRN2: shall return false if the event is not set in the Toolkit Registry for the applet. 

5.2.5.2.1 .2 Parameter errors 
No requirements. 

5.2.5.2.1 .3 Context errors 
No requirements. 

5.2.5.2.2 

Test Source: 
Test Applet: 
Cap File: 



5.2.5.2.3 



Test area files 

Test_Api_2_Tkr_Ie vs .j ava 
Api_2_Tkr_Ie vs_ 1 .j ava 
Api_2_Tkr_Ie vs . cap 

Test coverage 



CRR number 


Test case number 


N1 


2 


N2 


1 



5.2.5.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Install Applet only registered to 

EVENT_EVENT_DOWNLOAD_USER_ACTIVITY 

Test that events are not set 

Applet calls isEventSetO method for each 
event ranging from (2 to 6, 10 and 24) 


Shall return false each time. 




2 


Setting events 

For the following events defined in 
TS 31.130 [2] for setEventO method: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

applet calls: 

1- Call setEventO method 

2- Call isEventSetO method 


1- No exception shall be thrown. 

2- Shall return true each time. 





5.2.5.3 



Method setEvent 
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Test Area Reference: Api_2_Tkr_Sevt 

5.2.5.3.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void setEvent (short id) 

throws ToolkitException, 

javacard. framework .TransactionException 

5.2.5.3.1.1 Normal execution 

• CRRNl: a following call to isEventSet() method with the same event id shall answer true for the applet. 

• CRRN2: the (U)S AT Framework shall trigger the applet if an occurrence of the set event happens. 

5.2.5.3.1.2 Parameter errors 
No requirements. 

5.2.5.3.1.3 Context errors 

• CRRC 1 : shall throw a ToolkitException with E VENT_ALREAD Y_REGISTERED if event is 
EVENT_MO_SHORT_MESSAGE_CONTROL_B Y_SIM but another applet is already registered to it. 

• CRRC2: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if event is 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM but another applet that it is not in selectable state is 
already registered to it. 

• CRRC3: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_PP_ENV 
and the applet has no TAR defined. 

• CRRC4: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_PP_UPD 
and the applet has no TAR defined. 

• CRRC5: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_CB and 
the applet has no TAR defined. 



5.2.5.3.2 

Test Source: 
Test Applet: 



Cap File: 
5.2.5.3.3 



Test area files 

Test_Api_2_Tkr_Sevt.j ava 

Api_2_Tkr_Sevt_l .Java 

Api_2_Tkr_Sevt_2.java 

Api_2_Tkr_Sevt_3 .j ava 

The load script installs the 3 instances. 

Api_2_Tkr_Sevt.cap 

Test coverage 



CRR number 


Test case number 


N1 


1 


N2 


2,3 


C1 


4 
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C2 


5 


C3 


6 


C4 


6 


C5 


6 



5.2.5.3.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework Expectation 


APDU 
Expectation 


1 


Setting events 

1- For events (2 to 6, 10 and 24) defined in 
TS 31.130 [2] : 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

1.1- Call clearEvent (event) 

1.2- Call isEventSet (event) 

1.3- Call setEvent (event) 

1.4- Call IsEventSet (event) 

1.5- Call clearEvent (event) 


1.1- No exception shall be thrown. 

1 .2- Shall return false. 

1 .3- No exception shall be thrown. 

1 .4- Shall return true. 

1 .5- No exception shall be thrown. 




2 


Setting 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

Call 

setEvent (EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM) 


No Exception shall be thrown 




3 


Check applet is triggered by an ENVELOPE 
(EVENT MO SHORT MESSAGE CONTROL BY SIM 

) 

Trigger the applet 


Applet is triggered by an ENVELOPE 
(EVENT MO SHORT MESSAGE C 
ONTROL_BY_SIM) 




4 


Applet2 registers to 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

but it is already assigned 

1- Trigger Applet2 by 

ENVELOPE (EVENT_FORMATTED_SMS_PP_ENV) 

2- Applet2 call 

setEvent (EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM) 


2- Shall throw a ToolkitException with 
EVENT_ALREADY_REGISTERED 
reason code. 
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Id 


Description 


API/(U)SAT Framework Expectation 


APDU 
Expectation 


5 


Applet2 registers to 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

but it is already assigned to another applet in not 

selectable state 

1- Set the Appletl in the lock state 

2- Applet2 call setEvent 

(EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM) 

3- Set the Appletl in the make selectable state 


2- Shall throw a ToolkitException with 
EVENT_ALREADY_REGISTERED 
reason code. 




6 


Applet3 with no TAR defined registers to 
EVENT_UNFORMATTED_SMS_CB event 

1- send unformatted 

ENVELOPE (CELL_BROADCAST_DATA_DOWNLOAD) 

2- setEvent (EVENT_FORMATTED_SMS_PP_ENV) 

3- setEvent (EVENT_FORMATTED_SMS_PP_UPD) 

4- setEvent (EVENT_FORMATTED_SMS„CB) 


1 - Applets shall be triggered 

2- ToolkitException with reason code 
TAR_NOT_DEFINED shall be thrown 

3- ToolkitException with reason code 
TAR_NOT_DEFINED shall be thrown 

4- ToolkitException with reason code 
TAR_NOT_DEFINED shall be thrown 





5.2.5.4 Method setEventList 

Test Area Reference: Api_2_Tkr_Sevl 

5.2.5.4.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void setEventList (short [ ] eventList, 

short offset, 
short length) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 

ToolkitException, 

javacard. framework .TransactionException 

5.2.5.4.1.1 Normal execution 

• CRRNl: for all events set successfully by this method, a call to isEventSet() method should return true. 

• CRRN2: the (U)SAT Framework shall trigger the applet if an occurrence of one of the successfully registered 
events happens. 

5.2.5.4.1.2 Parameter errors 
No requirements. 

5.2.5.4.1 .3 Context errors 

• CRRC 1 : shall throw a ToolkitException with E VENT_ALREAD Y_REGISTERED if eventList contains 
EVENT_MO_SHORT_MESSAGE_CONTROL_B Y_SIM but another applet is already registered to it. 

• CRRC2: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if event is 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM but another applet that it is not in selectable state is 
already registered to it. 
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• CRRC3: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_PP_ENV 
and the applet has no TAR defined. 

• CRRC4: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_PP_UPD 
and the applet has no TAR defined. 

• CRRC5: shall throw a ToolkitException with TAR_NOT_DEFINED if event is FORMATTED_SMS_CB and 
the applet has no TAR defined. 



5.2.5.4.2 

Test Source: 
Test Applet: 

Cap File: 
5.2.5.4.3 



Test area files 

Test_Api_2_Tkr_Sevl.j ava 
Api_2_Tkr_Sevl_l .Java 
Api_2_Tkr_Sevl_2.java 
Api_2_Tkr_Sevl.cap 

Test coverage 



CRR number 


Test case number 


N1 


1,2 


N2 


3,4 


C1 


5 


C2 


6 


C3 


7 


C4 


7 


C5 


7 



5.2.5.4.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Appletl registers all eventList buffer 

EventList = events (2 to 6, 10 and 24) defined 
in TS 31.130 [2] : 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

1- For each event in EventList 

clearEvent (event) 

2- Call setEventList (eventList) 

Offset = 

Length = eventList . length 

3- For all events in eventList 
isEventSet (event) 

4- For each event in EventList 
clearEvent (event) 


1- No exception shall be thrown. 

2- No exception shall be thrown. 

3- Each time shall return true. 

4- No exception shall be thrown. 




2 


Registering part of eventList buffer 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EventList = events (2 to 6, 10 and 24) defined 
in TS 31.130 [2] : 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

1- For each event in EventList 

clearEvent (event) 

2- setEventList (eventList, offset, length) 

Offset > 

Length = eventList . lentgh - offset 

3- For all events in eventList: 

Call isEventSet (event) 

4- For each event in EventList: 

clearEvent (event) 


1 - No exception shall be thrown. 

2- No exception shall be thrown. 

3- Each time shall return true for 
events ranging from offset to 
offset+length else shall return 
false. 

4- No exception shall be thrown. 




3 


Setting EVENT MO SHORT MESSAGE 
CONTROL_BY_SIM 

Call setEventList (MonoEventList, 0, 1) with 
MonoEventList containing 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 


Shall not throw an exception 




4 


Check appletl is triggered by an ENVELOPE 

(EVENT MO SHORT MESSAGE 

CONTROL_BY_SIM) 

Reset and initialize the card 
Trigger the applet 


Applet is triggered by an 
ENVELOPE 

(EVENT MO SHORT MESSAGE 
CONTROL BY SIM) 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


5 


Applet 2 registers to 

EVENT MO SHORT MESSAGE 

CONTROL_BY_SIM 

but it is already assigned 

Call setEventList (MonoEventList, 0, 1) with 
MonoEventList containing 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 


Shall throw a ToolkitException 
with 

EVENT_ALREADY_REGISTERE 
D reason code. 




6 


Applet2 registers to 
EVENT MO SHORT MESSAGE CONTROL BY SI 

M 

but it is already assigned to another applet in not 

selectable state 

1- Set the Appletl in the lock state 

2- Applet2 calls 

setEventList (MonoEventList, 0, 1) with 
MonoEventList containing 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

3- Set the Appletl in the make selectable 

state 


2- Shall throw a ToolkitException 
with 

EVENT_ALREADY_REGISTERE 
D reason code. 




7 


Applet3 with no TAR defined registers to 
EVENT_UNFORMATTED_SMS_CB event 

1- send unformatted 

ENVELOPE (CELL_BROADCAST_DATA_DOWNLOAD) 

2- setEventList (EventList, 0, 1) with EventList 
containing EVENT_FORMATTED_SMS_PP_ENV 

3- setEventList (EventList , 1, 1 ) with EventList 
containing EVENT_FORMATTED_SMS_PP_UPD 

4- setEventList (EventList , 2, 1 ) with EventList 
containing EVENT_FORMATTED_SMS_CB 

5- isEventSet (EVENT_FORMATTED_SMS_PP_ENV) 

6- isEventSet (EVENT_FORMATTED_SMS_PP_UPD) 

7- IsEventSet (EVENT_FORMATTED_SMS„CB) 


1- Applets shall be triggered 

2- ToolkitException with reason 
code TAR_NOT_DEFINED shall 
be thrown 

3- ToolkitException with reason 
code TAR_NOT_DEFINED shall 
be thrown 

4- ToolkitException with reason 
code TAR_NOT_DEFINED shall 
be thrown 

5- method shall return FALSE 

6- method shall return FALSE 

7- method shall return FALSE 
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5.3 (U)SAT Framework 

5.3.1 Minimum handler availability 
5.3.1.1 ProactiveHandler 

Test Area Reference: Ufw_Mha_Pahd 

5.3.1 .1 .1 Conformance requirements 

5.3.1.1.1.1 Normal execution 

• CRRNl: If a proactive session is not ongoing the ProactiveHandler is available from the invocation to the 
termination of the processToolkit() method for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

• CRRN2: A ProactiveHandler is considered available when no HANDLER_NOT_AVAILABLE 

ToolkitException is thrown when the corresponding getTheHandler() method is called or a method of the 
handler is called. 

• CRRN3: When available the ProactiveHandler shall remain available until the termination of the 
processToolkitO method. 

• CRRN4: If a proactive command is pending the ProactiveHandler may not be available. 

5.3.1.1.1.2 Parameter errors 
No requirements. 

5.3.1.1.1.3 Context errors 

• CRRCl : The ProactiveHandler shall not be available if the Terminal Profile command has not yet been 
processed by the (U)SAT Framework. 

5.3.1.1.2 Test area files 

Test Source: Test_Ufw_Mha_Pahd.java 

Test Applet: Ufw_Mha_Pahd_l.java 

Ufw_Mha_Pahd_2.j ava 
Cap File: Ufw_Mha_Pahd.cap 
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5.3.1.1.3 



Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 14 


N3 


1 to 7 


N4 


Not testable 


CI 


8 to 14 and also tested in Test Cases 8 to 14 in Ufw_Mha_Prhd. 

Applicable only if the applet is triggerred when no terminal profile 

has been previously received. 



5.3.1.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


ProactiveHandler availability with 
EVENT_FORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 


1- Appletl is triggered 






2- Appletl gets the ProactiveHandler 


2- No exception is thrown. 
Appletl finalizes 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


2 


ProactivehHandler availability with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 

2- No exception is thrown. 
Appletl finalizes 




3 


ProactivehHandler availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Applet2 gets the ProactiveHandler 


1- Appletl is triggered 

2- No exception Is thrown. 

Appletl finalizes 
Applet2 is triggered 

3- No exception is thrown. 




4 


ProactiveHandler availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U) SIM 

2- Appletl gets the ProactiveHandler 

3- Applet2 gets the ProactiveHandler 


1- Appletl is triggered 

2- No exception Is thrown. 
Appletl finalizes 

3- Applet2 is triggered 

4- No exception is thrown. 




5 


ProactiveHandler availability with 
EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Applet2 gets the ProactiveHandler 


1- Appletl is triggered 

2- No exception is thrown 

Appletl finalizes 
Applet2 is triggered 

3- No exception is thrown 




6 


ProactiveHandler availability with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 
2- No exception is thrown 




7 


ProactiveHandler availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 






2-No exception is thrown 
Appletl finalizes 




8 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_FORMATTED_SMS_PP_ENV 

1- Reset the card without sending the 
Terminal Profile 

2- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 

3- Appletl gets the ProactiveHandler 


2- Appletl is triggered 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




9 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




10 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Applet2 gets the ProactiveHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 
Applet2 is triggered 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 




11 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U) SIM 

2- Appletl gets the ProactiveHandler 

3- Applet2 gets the ProactiveHandler 


1 - Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 
Applet2 is triggered 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 




12 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the (U) SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 
Applet2 is triggered 

3- A ToolkitException 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




3- Applet2 gets the ProactiveHandler 


HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 




13 


The ProactivehHandler is not available before 

the Terminal Profile with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




14 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 





5.3.1.2 



ProactiveResponseHandler 



Test Area Reference: Ufw Mha Prhd 



5.3.1.2.1 



5.3.1.2.1.1 



Conformance requirements 
Normal execution 



• CRRNl: The ProactiveResponseHandler is available as soon as the ProactiveHandler is available and remains 
available until the termination of the processToolkit() method for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

• CRRN2: A ProactiveResponseHandler is considered available when no HANDLER_NOT_AVAILABLE 
ToolkitException is thrown when the corresponding g etThe Handle r() method is called or a method of the 
handler is called. 

5.3.1.2.1.2 Parameter errors 
No requirements. 

5.3.1.2.1.3 Context errors 

• CRRCl : The ProactiveResponseHandler shall not be available if the ProactiveHandler is not available. 
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5.3.1.2.2 

Test Source: 
Test Applet: 

Cap File: 
5.3.1.2.3 



Test area files 

Test_Ufw_Mha_Prhd.j ava 
Ufw_Mha_Prhd_ 1 .j ava 
Ufw_Mha_Prhd_2.j ava 
Ufw_Mha_Prhd.cap 

Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 14 


C1 


8 to 14. 

Applicable only if the applet is triggerred when no terminal 

profile has been previously received. 
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5.3.1.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


ProactiveResponseHandler availability with 
EVENT_FORIVIATTED_SIVIS_PP_ENV 

1- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 

Applet builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send ( ) method is 
called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 
3- No exception is tlirown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 


2 


ProactiveResponseHandler availability with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

Applet builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send ( ) method is 
called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 
3- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 


3 


ProactiveResponseHandler availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

Appletl builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send method is 
called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 

Applet2 builds a proactive command DISPLAY 
TEXT 

4- ProactiveHandler . send method is 
called 

5- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 

3- No exception is thrown 

Appletl finalizes 
Applet2 is triggered 

5- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 

4- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 


4 


ProactiveResponseHandler availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




unformatted is sent to the (U) SIM 

Appletl builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send ( ) method is 
called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 

Applet2 builds a proactive command DISPLAY 
TEXT 

4- ProactiveHandler . send method is 
called 

5- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 

3- No exception is tlirown 

Appletl finalizes 
Applet2 is triggered 

5- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 

4- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 


5 


ProactiveResponsehHandler availability with 
EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the (U) SIM 

Appletl builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send ( ) method is called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called. 

Applet2 builds a proactive command DISPLAY 
TEXT 

4- ProactiveHandler . send method is 
called 

5- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 

3- No exception is thrown 

Appletl finalizes 
Applet2 is triggered 

5- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 

4- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


6 


ProactiveResponsehHandler availability with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the {U)SIM 

Applet builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send method is 
called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called 


1- Appletl is triggered 
3- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 
TERMINAL RESPONSE 


7 


ProactiveResponsehHandler availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the (U)SIM 

Appletl builds a proactive command DISPLAY 
TEXT 

2- ProactiveHandler . send ( ) method is called 

3- 

ProactiveResponseHandler . getTheHandler ( ) 

method is called. 


1- Appletl is triggered 
3- No exception is thrown 


2- A proactive command 
DISPLAY TEXT is fetched 

TERMINAL RESPONSE 


8 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_FORMATTED_SMS_PP_ENV 

1- Reset the card without sending the 
Terminal Profile 

2- Envelope SMS-PP Download formatted is 
sent is sent to the (U)SIM 

3- Appletl gets the ProactiveHandler 

4- Appletl gets the 
ProactiveResponseHandler 


2- Appletl is triggered 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE Is 
thrown 

4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




9 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




10 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 


1- Appletl is triggered 
2- A ToolkitException 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 

4- Applet2 gets the ProactiveHandler 

5- Applet2 gets the 
ProactiveResponseHandler 


HANDLER_NOT_AVAILABLE is 
thrown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 
Applet2 is triggered 

4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


11 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 

4- Applet2 gets the ProactiveHandler 

5- Applet2 gets the 
ProactiveResponseHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
tlirown 

Appletl finalizes 
Applet2 is triggered 

4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 




12 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 

4- Applet2 gets the ProactiveHandler 

5- Applet2 gets the 
ProactiveResponseHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 
Applet2 is triggered 

4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Applet2 finalizes 




13 


The ProactiveHandler is not available before 

the Terminal Profile with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 


1 - Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 




14 


The ProactiveHandler is not available before 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




the Terminal Profile with 
EVENT_FORMATTED_SMS_CB 

1- lope Cell Broadcast Download formatted 
is sent to the (U)SIM 

2- Appletl gets the ProactiveHandler 

3- Appletl gets the 
ProactiveResponseHandler 


1- Appletl is triggered 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
tlirown 

3- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 





5.3.1.3 EnvelopeHandler 

Test Area Reference: Ufw Mha Enhd 



5.3.1.3.1 



5.3.1.3.1.1 



Conformance requirements 
Normal execution 



CRRNl: The EnvelopeHandler and its content are available for all toolkit applets triggered from the 
invocation to the termination of \heii processToolkit() method for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

CRRN2: An EnvelopeHandler is considered available when no HANLDER_NOT_AVAILABLE 
ToolkitException is thrown when the corresponding getTheHandler() method is called or a method of the 
handler is called. 



5.3.1.3.1.2 

No requirements. 

5.3.1.3.1.3 

No requirements. 

5.3.1.3.2 

Test Source : 
Test Applet: 

Cap File : 



Parameter errors 

Context Errors 

Test area files 

Test_Ufw_Mha_Enhd.j ava 
Ufw_Mha_Enhd_ 1 .j ava 
Ufw_Mha_Enhd_2.j ava 
Uf w_Mha_Enhd . c ap 
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5.3.1.3.3 



Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 7 



5.3.1.3.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


EnvelopeHandler availability with 
EVENT_FORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 

2- EnvelopeHandler .getTheHandler method 
is called by Appletl 


1- Appletl is triggered 
2- No exception is thrown. 




2 


EnvelopeHandler availability with 
EVENT_FORMATTED_SIVIS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- EnvelopeHandler .getTheHandler method 
is called by Appletl 


1- Appletl is triggered 
2- No exception Is thrown. 




3 


EnvelopeHandler availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- EnvelopeHandler .getTheHandler method 
is called by Appletl 

3- EnvelopeHandler . getTheHandler ( ) method 
is called by Applet2 


1- Appletl is triggered 

2- No exception Is thrown. 
Appletl finalizes 

3- Applet2 is triggered 

4- No exception Is thrown. 




4 


EnvelopeHandler availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U) SIM 

2- EnvelopeHandler . getTheHandler ( ) method 
is called by Appletl 

3- EnvelopeHandler .getTheHandler method 
is called by Applet2 


1- Appletl is triggered 

2- No exception Is thrown. 

Appletl finalizes 
Applet2 is triggered 

3- No exception is thrown. 




5 


EnvelopeHandler availability with 
EVENT_UNFORMATTED_SMS_CB 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




1- Envelope Cell Broadcast Download 
unformatted is sent to the (U) SIM 

2- EnvelopeHandler .getTheHandler method 
is called by Appletl 

3- EnvelopeHandler . getTheHandler ( ) method 
is called by Applet2 


1- Appletl is triggered 

2- No exception is tlirown 
Appletl finalizes 

3- Applet2 is triggered 

4- No exception is thrown 




6 


EnvelopehHandler availability with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- EnvelopeHandler .getTheHandler method 

is called by Appletl 


1- Appletl is triggered 

2- No exception Is throw 




7 


EnvelopeHandler availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the (U)SIM 

2- EnvelopeHandler . getTheHandler ( ) method 
is called by Appletl 


1- Appletl is triggered 
2-No exception is thrown 





5.3.1.4 EnvelopeResponseHandler 

Test Area Reference: Ufw_Mha_Erhd 



5.3.1.4.1 



5.3.1.4.1.1 



Conformance requirements 



Normal execution 



• CRRNl: The handler is available for all triggered toolkit applets from the invocation of the processToolkit() 
method of the toolkit applet until a toolkit applet has posted an envelope response or the first invocation of the 
ProactiveHandler.sendO method for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

• CRRN2: An EnvelopeResponseHandler is considered available when no HANLDER_NOT_AVAILABLE 
ToolkitException is thrown when the corresponding getTheHandlerQ method is called or a method of the 
handler is called. 

5.3.1.4.1.2 Parameter errors 
No requirements. 

5.3.1.4.1.3 Context Errors 

• CRRCl: The handler is not available for the following events: 

EVENT_FORMATTED_SMS_PP_UPD 
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5.3.1.4.2 
Test Source: 
Test Applet: 

Cap File: 
5.3.1.4.3 



Test area files 

Test_Ufw_Mha_Erhd.j ava 
Ufw_Mha_Erhd_ 1 .j ava 
Ufw_Mha_Erhd_2.j ava 
Ufw_Mha_Erhd.cap 

Test coverage 



CRR Number 


Test Case Number 


N1 


5 to 8 


N2 


1 to 8 


C1 


1 to 4 



5.3.1.4.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


EnvelopeResponseHandler availability with 
EVENT_FORIVIATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- The appletl is triggered. 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 




2 


EnvelopeResponseHandler availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U) SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered. 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE Is 
thrown 




3 


EnvelopeResponseHandler availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- The appletl is triggered. 

2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 
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EnvelopeResponseHandler availability with 
EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the SIM 



2- EnvelopeResponseHandler . getThetiandler ( ) 
method is called by Appletl 



1- Appletl is triggered. 



2- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
tlirown 
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EnvelopeResponseHandler availability with 
EVENT FORMATTED SMS PP ENV 



1- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 



2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 

3- Appletl builds an additional 
information for response packet and it 
calls the postO method 

4- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



5- A EVENT_FORMATTED_SMS_PP_ENV envelope 
is sent to the (U)SIM 



6- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 

7- Appletl builds a proactive command and 
it calls the sendO method 

8- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



1- Appletl is triggered 



2- No exception Is thrown. 



4- A ToolkitException 
HANDLER_NOT_AVAILABLE Is 
thrown for each method 

Appletl finalizes 

5- Appletl is triggered 



6- No Exception is thrown 



8- ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown for each method 



3- The response packet is 
sent 



7- The proactive command 
is sent 
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EnvelopeResponseHandler availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 



3- Appletl builds the envelope response 
and it calls the postO method 

4- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called 



6- An unformatted SMS PP envelope is sent 
to the (U)SIM 



7- EnvelopeResponseHandler . getTheHandler ( ) 
method is called. 

8- Appletl builds a proactive command and 
it calls the sendO method 



9- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



10- 

EnvelopeResponseHandler . getTheHandler ( ) 

method is called by Applet2 



1- Appletl is triggered 



2- No exception Is thrown. 



4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
tlirown for each method 
Appletl finalizes 

5- Applet2 is triggered. 



A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown. 

Applet2 finalizes 

6- Appletl is triggered. 



7- No exception Is thrown. 



9- A ToolkitException 
HANDLER_NOT_AVAILABLE Is 
thrown for each method. 

Appletl finalizes 

10- Applet2 is triggered. 



A ToolkitException 
HANDLER_NOT_AVAILABLE Is 
thrown. 



3- The envelope response is 
sent 



9- The proactive command 
is fetched and the Terminal 
response Is issued. 
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EnvelopeResponseHandler availability with 

EVENT_MO_SHORT_MESSAGE_CONTROL_B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 

3- Appletl builds the envelope response 
and it calls the postAsBERTLV () method 

4- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



5- Envelope MO short message control by 
SIM is sent to the (U)SIM 

6- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 

7- Appletl builds a proactive command and 
it calls the send method 

8- Appletl calls all methods of the 
EnvelopeResponseHandler (including 
inherited methods) 



1- Appletl is triggered 



2- No exception Is thrown. 



4- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown for each method 

Appletl finalizes 

5- Appletl is triggered 



6- No exception is thrown 



8- A Tooll<itException 
HANDLER_NOT_AVAILABLE is 
thrown for each method 



3-The envelope response is 
sent 



7- The proactive command 
is fetched and the Terminal 
Response is issued 
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8 


EnvelopeResponseHandler availability with 

EVENT_UNFORMATTED_SMS_PP_ENV in case 

of multi-triggering 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Applet 2 

6- Applet2 calls the postO method 


1- Appletl is triggered 

2- No exception is thrown. 

3- Appletl finalizes 

4- Applet2 is triggered. 

5- No Exception is thrown 

Applet2 finalizes 


6- The response is checked. 



5.3.1.5 USATEnvelopeHandler 

Test Area Reference: Ufw_Mha_Uehd 



5.3.1.5.1 



5.3.1.5.1.1 



Conformance requirements 
Normal execution 



CRRNl: The UsatEnvelopeHandler and its content are available for all toolkit applets triggered from the 
invocation to the termination of their processToolkit() method for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_CB 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

EVENT_FORMATTED_SMS_CB 

CRRN2: An UsatEnvelopeHandler is considered available when no HANLDER_NOT_AVAILABLE 
ToolkitException is thrown when the corresponding getTheHandler() method is called or a method of the 
handler is called. 



5.3.1.5.1.2 

No requirements. 

5.3.1.5.1.3 

No requirements. 



Parameter errors 



Context Errors 
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5.3.1.5.2 

Test Source 
Test Applet: 

Cap File : 
5.3.1.5.3 



Test area files 

Test_Ufw_Mha_Uehd.j ava 
Ufw_Mha_Uehd_ 1 .j ava 
Ufw_Mha_Uehd_2 .j ava 
Ufw_Mha_Uehd.cap 

Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 7 



5.3.1.5.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


USATEnvelopeHandler availability with 
EVENT_FORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 
2- No exception is thrown. 




2 


USATEnvelopeHandler availability with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 
2- No exception Is thrown. 




3 


USATEnvelopeHandler availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 

3- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Applet2 


1- Appletl is triggered 

2- No exception Is thrown. 
Appletl finalizes 

3- Applet2 is triggered 

4- No exception Is thrown. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


4 


USATEnvelopel-landler availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction 
unformatted is sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 

3- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Applet2 


1- Appletl is triggered 

2- No exception is thrown. 

Appletl finalizes 
Applet2 is triggered 

3- No exception is thrown. 




5 


USATEnvelopeHandler availability with 
EVENT_UNFORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
unformatted is sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 

3- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Applet2 


1- Appletl is triggered 

2- No exception is thrown 
Appletl finalizes 

3- Applet2 is triggered 

4- No exception is thrown 




6 


USATEnvelopeHandler availability with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope MO short message control by 
SIM is sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 
2- No exception is throw 




7 


USATEnvelopeHandler availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope Cell Broadcast Download 
formatted is sent to the (U)SIM 

2- USATEnvelopeHandler. getTheHandler 
method is called by Appletl 


1- Appletl is triggered 
2-No exception is thrown 





5.3.1 .6 Applet triggering with ongoing proactive session 

Test Area Reference: Ufw_Mha_Rent 

5.3.1.6.1 Conformance requirements 

5.3.1.6.1.1 Normal execution 

• CRRNl: EnvelopeHandler and USATEnvelopeHandler are available for all events. 

• CRRN2: EnvelopeResponseHandler is available for the following events: 

EVENT_FORMATTED_SMS_PP_ENV 

EVENT_UNFORMATTED_SMS_PP_ENV 

EVENT MO SHORT MESSAGE CONTROL BY SIM 
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• CRRN3: Reply busy is not allowed for following events: 

EVENT_FORMATTED_SMS_PP_UPD 

EVENT_UNFORMATTED_SMS_PP_UPD 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

5.3.1.6.1.2 Parameter errors 
No requirements. 

5.3.1.6.1.3 Context Errors 

• CRRCl: EnvelopeResponseHandler is not available for the following events: 

EVENT_FORMATTED_SMS_PP_UPD 
EVENT_UNFORMATTED_SMS_PP_UPD 
EVENT_UNFORMATTED_SMS_CB 
EVENT_FORMATTED_SMS_CB 



5.3.1.6.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.1.6.3 



Test area files 

Test_Ufw_Mha_Rent.j ava 
Ufw_Mha_Rent_ 1 .j ava 
Ufw_Mha_Rent.cap 

Test coverage 



CRR Number 


Test Case Number 


N1 


1,2,3,4,5,6,7 


N2 


3,4,5 


N3 


1,2,3 


CI 


1,2,6,7 
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5.3.1.6.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


[Handlers availability with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the sendO method 

3- Update Record EFsms instruction 
formatted is sent to the (U)SIM 

4- EnvelopeHandler . getTheHandler ( ) and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler { ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 


2- 91 XX 

6- The proactive command Is 
fetched and the Terminal 
Response is issued. 


2 


Handlers availability with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the send() method 

3- Update Record EFsms instruction 
unformatted is sent to the (U)SIM 

4- EnvelopeHandler .getTheHandler and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 


2- 91 XX 

6- The proactive command is 
fetched and the Terminal 
Response is issued. 


3 


Handlers availability with 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the send() method 

3- Envelope MO short message control by 
SIM is sent to the (U)SIM 

4- EnvelopeHandler . getTheHandler ( ) and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- No exception is thrown 
Appletl finalizes 


2- 91 XX 

6- The proactive command is 
fetched and the Terminal 
Response is issued. 


4 


Handlers availability with 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EVENT_FORIVIATTED_SIVIS_PP_ENV 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the sendO method 

3- Envelope SMS-PP Download formatted is 
sent to the (U)SIM 

4- EnvelopeHandler . getTheHandler ( ) and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- No exception is thrown 
Appletl finalizes 


2- 91 XX 

6- The proactive command is 
fetched and the Terminal 
Response is issued. 


5 


[Handlers availability with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- Envelope unrecognized is sent to the 
{U)SIM 

2- Appletl builds a proactive command and 
calls the sendO method 

3- Envelope SMS-PP Download unformatted is 
sent to the (U)SIM 

4- EnvelopeHandler . getTheHandler ( ) and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- No exception is thrown 
Appletl finalizes 


2- 91 XX 

6- The proactive command is 
fetched and the Terminal 
Response is issued. 


6 


Handlers availability with 
EVENT_FORMATTED_SMS_CB 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the sendO method 

3- Envelope CB Download formatted is sent 
to the (U)SIM 

4- EnvelopeHandler .getTheHandler and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


1- Appletl is triggered 

3- Appletl is triggered again 

4- No exception is thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 


2- 91 XX 

6- The proactive command is 
fetched and the Terminal 
Response is issued. 


7 


Handlers availability with 
EVENT_UNFORIVIATTED_SIVIS_CB 

1- Envelope unrecognized is sent to the 
(U)SIM 

2- Appletl builds a proactive command and 
calls the send{) method 


1- Appletl is triggered 


2- 91 XX 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




3- Envelope CB Download unformatted is 
sent to the (U)SIM 

4- EnvelopeHandler .getTheHandler and 
USATEnvelopeHandler . getTheHandler ( ) 
methods are called by Appletl 

5- EnvelopeResponseHandler . getTheHandler ( ) 
method is called by Appletl 


3- Appletl is triggered again 

4- No exception is thrown 

5- A ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 

Appletl finalizes 


6- The proactive command is 
fetched and the Terminal 
Response is issued. 



5.3.2 Handler integrity 

5.3.2.1 ProactiveResponseHandler 

Test Area Reference: Ufw Hin Prhd 



5.3.2.1.1 
5.3.2.1.1.1 



Conformance requirements 
Normal execution 



CRRNl: The ProactiveResponseHandler TLV list shall be empty before the first call to the 
Proactive Handle r.sendO method. 



5.3.2.1.1.2 

No requirements. 

5.3.2.1.1.3 

No requirements. 

5.3.2.1.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.2.1.3 



Parameter errors 

Context Errors 

Test area files 

Test_Ufw_Hin_Prhd.j ava 
Ufw_Hin_Prhd_ 1 .j ava 
Uf w_Hin_Prhd . c ap 

Test coverage 



CRR Number 


Test Case Number 


N1 


1 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Applet registration and 
ProactiveResponseHandler obtaining 

1- Applet is registered to all events 
defined in TS 31.130 [2] . 

Using the method setEventList ( ) for all 
the events . 








Terminal Profile command is sent to the 
(U)SIM without the facilities of 
SET_EVENT_LIST , SETUP_IDLE_MODE_TEXT, 
SETUP_MENU and POLL_INTERVAL . 


1 - No exception is thrown 






2- For each event/triggering: 


2- Applet is triggered. 






3 

ProactiveResponseHandler . getTheHandler ( ) 

is called 


3- No exception is thrown 






4- ProactiveResponseHandler .getLength is 








called 


4- The return value is 





5.3.2.2 EnvelopeHandler 

Test Area Reference: Ufw_Hin_Enhd 



5.3.2.2.1 



5.3.2.2.1.1 



Conformance requirements 
Normal execution 



CRRNl: When available, the EnvelopeHandler shall remain available and its content shall remain unchanged 
from the invocation to the termination of the processToolkit() method. 

CRRN2: The EnvelopeHandler TLV list is filled with the Comprehension TLV data objects of the 
ENVELOPE APDU command. The Comprehension TLV data objects shall be provided in the order given in 
the ENVELOPE command data. 



5.3.2.2.1.2 

No requirements. 

5.3.2.2.1.3 

No requirements. 

5.3.2.2.2 

Test Source: 
Test Applet: 
Cap File: 



Parameter errors 

Context Errors 

Test area files 

Test_Ufw_Hin_Enhd.java 
Ufw_Hin_Enhd_ 1 .j ava 
Ufw_Hin_Enhd.cap 
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5.3.2.2.3 



Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 7 
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5.3.2.2.4 



Test procedure 



Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



EnvelopeHandler integrity checks with 
EVENT_FORI\/IATTED_SIVIS_PP_ENV 

1- A formatted SMS PP envelope is sent to 
the (U)SIM 



2- EnvelopeHandler . getTheHandler ( ) method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 

The EnvelopeHandler . findTLV ( ) method is 
called with TAG_SMS__TPDU 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



EnvelopeHandler .getTheHandler method is 
called 

6- Check that EnvelopeHandler content is 
the same as in the envelope call control 
using EnvelopeHandler . copy ( ) and 
Util . arrayCompare {) methods 

The EnvelopeHandler . findTLV ( ) method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



Check that the TAG_SMS_TPDU is the TLV 
selected 

7- The content of EnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



4- 91 XX 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



Proactive command Display 
Text is fetched 
The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl 



EnvelopeHandler integrity checks with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction single 
and formatted is sent to the (U)SIM 

2- EnvelopeHandler . getTheHandler ( ) method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 

The EnvelopeHandler . findTLV ( ) method is 
called with TAG_SMS_TPDU 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



4- 91 XX 



5- Applet is triggered 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EnvelopeHandler . getTheHandler ( ) method is 
called 








6- Checked that EnvelopeHandler content is 








the same as in envelope call control using 
EnvelopeHandler . copy ( ) and 
Util . arrayCompare ( ) methods 

The EnvelopeHandler . findTLV method is 
called with TAG_SMS_TPDU 


6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 






Call Control execution is finished. 








Checked that the TAG_SMS_TPDU is the TLV 
selected 




Proactive command Display 
Text is fetched 
The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 




7- The content of EnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 


7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



EnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- A unformatted SMS PP envelope is sent 
to the (U)SIM 



2- EnvelopeHandler .getTheHandler method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 



The EnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



EnvelopeHandler . getTheHandler ( ) method is 
called 

6- Check that EnvelopeHandler content is 
the same as in the envelope call control 
using EnvelopeHandler . copy ( ) and 
Util . arrayCompare ( ) methods 

The EnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



Check that the TAG_DEVICE_IDENTITIES is 
the TLV selected 

7- The content of EnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



1- Applet is triggered 



2- No exception Is thrown. 



3- No exception Is thrown. 



4- 91 XX 



5- Applet Is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 



EnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction single 
and unformatted is sent to the (U)SIM 



2- EnvelopeHandler . getTheHandler ( ) method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 



The EnvelopeHandler . findTLV method is 
called with TAG_SMS_TPDU 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the {U)SIM 



1- Applet Is triggered 



2- No exception Is thrown. 



3- No exception Is thrown. 



4- 91 XX 



5- Applet is triggered 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EnvelopeHandler . getTheHandler ( ) method is 
called 

6- Check that EnvelopeHandler content is 
the same as in envelope call control using 
EnvelopeHandler . copy and 

Util . arrayCompare ( ) methods 

The EnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 

Check that the SMS_TPDU is the TLV 
selected 

7- The content of EnvelopeHandler is 
compared with bufferl using 

Util . arrayCompare () 


6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 

7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 


Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



EnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_CB 

1- An unformatted cell broadcast envelope 
is sent to the (U)SIM 



2- EnvelopeHandler . getTheHandler ( ) method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 



The EnvelopeHandler . findTLV ( ) method is 
called with TAG_CELLBROADCAST_PAGE 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 

EnvelopeHandler .getTheHandler method is 
called 

6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 
EnvelopeHandler . copy ( ) and 

Util . arrayCompare {) methods 

The EnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



1- Applet is triggered 



2- No exception Is thrown. 



3- No exception Is thrown. 



4- 91 XX 



5- Applet Is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



Check that the TAG_CELLBROADCAST_PAGE is 
the TLV selected 

7- The content of EnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 



EnvelopeHandler integrity checks with EVENT 
MO_SHORT_MESSAGE_CONTROL_BY_SIM 

1- A MO short message control by SIM 
envelope is sent to the (U) SIM 



2- EnvelopeHandler . getTheHandler ( ) method 
is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 

The EnvelopeHandler . findTLV ( ) method is 
called with TAG_ADDRESS 

4- A proactive command DISPLAY TEXT is 
sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



1- Applet is triggered 



2- No exception Is thrown. 



3- No exception Is thrown. 



4- 91 XX 



5- Applet Is triggered 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EnvelopeHandler . getTheHandler ( ) method is 
called 

6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 
EnvelopeHandler . copy and 

Util . arrayCompare ( ) methods 

The EnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 

Check that the TAG_ADDRESS is the TLV 
selected 

7- The content of EnvelopeHandler is 
compared with bufferl using 

Util . arrayCompare () 


6- No exception is thrown and the 
handler contains the envelope call 
control by SIIVI 

7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 


Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


7 


EnvelopeHandler integrity checks with 
EVENT_FORIVIATTED_SMS_CB 








1- A formatted cell broadcast envelope is 
sent to the (U)SIM 


1- Applet is triggered 






2- EnvelopeHandler . getTheHandler ( ) method 


2- No exception is tlirown. 






is called 








3- Copy the content of the EnvelopeHandler 
in bufferl using EnvelopeHandler . copy ( ) 


3- No exception is tlirown. 






The EnvelopeHandler . findTLV method is 








called with TAG_CELLBROADCAST_PAGE 




4- 91 XX 




4- A proactive command DISPLAY TEXT is 








sent 


5- Applet is triggered 






5- Envelope call control by SIM is sent to 








the (U)SIM 








EnvelopeHandler . getTheHandler ( ) method is 
called 


6- No exception is thrown and the 






6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 


handler contains the envelope call 
control by SIM 






EnvelopeHandler . copy and 








Util . arrayCompare ( ) methods 








The EnvelopeHandler . findTLV method is 








called with TAG_DEVICE_IDENTITIES 








Call Control execution is finished. 




Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 




Check that the TAG„CELLBROADCAST_PAGE is 
the TLV selected 




the (U)SIM 




7- The content of EnvelopeHandler is 








compared with bufferl using 
Util . arrayCompare ( ) 


7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 





5.3.2.3 



USATEnvelopeHandler 



Test Area Reference: Ufw Hin Uehd 



5.3.2.3.1 



5.3.2.3.1.1 



Conformance requirements 
Normal execution 



CRRNl: When available, the USATEnvelopeHandler shall remain available and its content shall remain 
unchanged from the invocation to the termination of the processToolkit() method. 

CRRN2: The USATEnvelopeHandler TLV list is filled with the Comprehension TLV data objects of the 
ENVELOPE APDU command. The Comprehension TLV data objects shall be provided in the order given in 
the ENVELOPE command data. 
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CRRN3: The (U)SAT Framework shall convert the UPDATE RECORD EFsms APDU into a 
COMPREHENSION TLV List containing Device Identities TLV, Address TLV, SMS TPDU TLV and AID 
TLV (only if the EFsms file updated is under an ADF). 

CRRN4: The getEnvelopeTag( ) method shall return BTAG_SMS_PP_DOWNLOAD. 

CRRN5: The getLength() method shall return the Comprehension TLV list length. 

CRRN6: The Device Identity Simple TLV is used to store the information about the absolute record number in 
the EFsms file ^nd the value of the EFsms record status byte. 



5.3.2.3.1.2 

No requirements. 

5.3.2.3.1.3 

No requirements. 

5.3.2.3.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.2.3.3 



Parameter errors 

Context Errors 

Test area files 

Test_Ufw_Hin_Uehd.j ava 
Ufw_Hin_Uehd_ 1 .j ava 
Ufw_Hin_Uehd.cap 

Test coverage 



CRR Number 


Test Case Number 


N1 


1 to 7 


N2 


1 to 7 


N3 


8,11 


N4 


10, 13 


N5 


9, 12 


N6 


8, 11 



5.3.2.3.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_FORMATTED_SMS_PP_ENV 

1- A formatted SMS PP envelope is sent to 
the (U)SIM 



2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_SMS_TPDU 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



USATEnvelopeHandler . getTheHandler { ) method 
is called 

6- Check that EnvelopeHandler content is 
the same as in the envelope call control 
using USATEnvelopeHandler . copy ( ) and 
Util . arrayCompare {) methods 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



Check that the TAG_SMS_TPDU is the TLV 
selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



4- 91 XX 



Proactive command Display 
Text is fetched 
The terminal Response of 
DISPLAY TEXT is sent to 
the {U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_FORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction single 
and formatted is sent to the (U)SIM 

2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_SMS_TPDU 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the {U)SIM 



USATEnvelopeHandler . getTheHandler ( ) method 
is called 

6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 
USATEnvelopeHandler . copy () and 
Util . arrayCompare methods 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_SMS_TPDU 

Call Control execution is finished. 



1- Applet is triggered 



2- No exception Is thrown. 



3- No exception is thrown. 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIIVI 



Checked that the TAG_SMS_TPDU is the TLV 
selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



4- 91 XX 



Proactive command Display 
Text is fetched 
The terminal Response of 
DISPLAY TEXT is sent to 
the {U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_PP_ENV 

1- A unformatted SMS PP envelope is sent to 
the (U)SIM 



2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 



The USATEnvelopeHandler . findTLV method is 
called with TAG_DEVICE_IDENTITIES 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



USATEnvelopeHandler . getTheHandler ( ) method 
is called 

6- Check that EnvelopeHandler content is 
the same as in the envelope call control 
using USATEnvelopeHandler . copy ( ) and 
Util . arrayCompare methods 

The USATEnvelopeHandler . findTLV method is 
called with TAG_.DEVICE_IDENTITIES 

Call Control execution is finished. 



Check that the TAG_DEVICE_IDENTITIES is the 
TLV selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare { ) 



1- Applet is triggered 



2- No exception Is thrown. 



3- No exception is thrown. 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



4- 91 XX 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the {U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- Update Record EFsms instruction single 
and unformatted is sent to the (U)SIM 



2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 



The USATEnvelopeHandler . findTLV method is 
called with TAG_SMS_TPDU 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 



USATEnvelopeHandler . getTheHandler ( ) method 
is called 

6- Check that EnvelopeHandler content is 
the same as in envelope call control using 
USATEnvelopeHandler . copy () and 
Util . arrayCompare methods 

The USATEnvelopeHandler . findTLV method is 
called with TAG_.DEVICE_IDENTITIES 

Call Control execution is finished. 



Check that the TAG_DEVICE_IDENTITIES is the 
TLV selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare { ) 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



4- 91 XX 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the {U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_UNFORMATTED_SMS_CB 

1- An unformatted cell broadcast envelope 
is sent to the (U)SIM 



2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 



The USATEnvelopeHandler . findTLVO method is 
called with TAG_CELLBROADCAST_PAGE 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 

USATEnvelopeHandler . getTheHandler ( ) method 
is called 

6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 
USATEnvelopeHandler . copy () and 

Util . arrayCompare methods 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



4- 91 XX 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



Check that the TAG_CELLBROADCAST_PAGE is 
the TLV selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


6 


USATEnvelopeHandler integrity checks with 

EVENT 
MO_SHORT_MESSAGE_CONTROL_BY_SIM 

1- A MO short message control by SIM 
envelope is sent to the (U) SIM 

2- USATEnvelopeHandler. getTheHandlerO 
method is called 


1- Applet is triggered 

2- No exception is thrown. 






3- Copy the content of the EnvelopeHandler 


3- No exception is thrown. 






in bufferl using USATEnvelopeHandler . copy ( ) 








The USATEnvelopeHandler . findTLVO method is 








called with TAG_ADDRESS 




4- 91 XX 




4- A proactive command DISPLAY TEXT is sent 








5- Envelope call control by SIM is sent to 
the (U)SIM 


5- Applet is triggered 






USATEnvelopeHandler . getTheHandler ( ) method 








is called 








6- Checked that EnvelopeHandler content is 


6- No exception is thrown and the 






the same as in envelope call control using 


handler contains the envelope call 






USATEnvelopeHandler . copy and 
Util . arrayCompare ( ) methods 


control by SIM 






The USATEnvelopeHandler . findTLVO method is 








called with TAG_DEVICE_IDENTITIES 








Call Control execution is finished. 




Proactive command Display 
Text is fetched 

The terminal Response of 




Check that the TAG_ADDRESS is the TLV 
selected 




DISPLAY TEXT is sent to 
the {U)SIM 




7- The content of USATEnvelopeHandler is 








compared with bufferl using 


7- The contents of the 






Util . arrayCompare ( ) 


EnvelopeHandler shall be the same 
as stored in bufferl. 
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Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



USATEnvelopeHandler integrity checks with 
EVENT_FORMATTED_SMS_CB 

1- A formatted cell broadcast envelope is 
sent to the (U)SIM 



2- USATEnvelopeHandler . getTheHandler ( ) 
method is called 



3- Copy the content of the EnvelopeHandler 
in bufferl using USATEnvelopeHandler . copy ( ) 



The USATEnvelopeHandler . findTLVO method is 
called with TAG_CELLBROADCAST_PAGE 

4- A proactive command DISPLAY TEXT is sent 

5- Envelope call control by SIM is sent to 
the (U)SIM 

USATEnvelopeHandler . getTheHandler ( ) method 
is called 

6- Checked that EnvelopeHandler content is 
the same as in envelope call control using 
USATEnvelopeHandler . copy () and 

Util . arrayCompare methods 

The USATEnvelopeHandler . findTLVO method is 
called with TAG_DEVICE_IDENTITIES 

Call Control execution is finished. 



1- Applet is triggered 



2- No exception is thrown. 



3- No exception is thrown. 



4- 91 XX 



5- Applet is triggered 



6- No exception is thrown and the 
handler contains the envelope call 
control by SIM 



Check that the TAG_CELLBROADCAST_PAGE is 
the TLV selected 

7- The content of USATEnvelopeHandler is 
compared with bufferl using 
Util . arrayCompare ( ) 



Proactive command Display 
Text is fetched 

The terminal Response of 
DISPLAY TEXT is sent to 
the (U)SIM 



7- The contents of the 
EnvelopeHandler shall be the same 
as stored in bufferl. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


8 


Check the TLV list conversion for 
EVENT_FORMATTED_SMS_PP_UPD 








1- An EVENT_FORMATTED_SMS_PP„UPD is sent to 
the (U)SIM. 


1- Applet is triggered. 






2- The findTLV(tag == device identities 
Tag) method is called. 


2- No exception is thrown. 






3- The getValueByte (of f set == 0) method is 
called. 


3- return the absolute record. 






4- The getValueByte (of f set == 1) method is 








called. 


4- return the record status. 






5- The findTLV(tag == address Tag) method 
is called. 


5- No exception is thrown. 






6- Check the content . 








7- The findTLV(tag == SMS TPDU Tag) method 








is called. 


7- No exception is thrown. 






8- Check the content. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


9 


getLengthO call 

Call getLengthO method 


return the Comprehension TLV list 
length 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


10 


getEnvelopeTagO call 

Call getTagO method 


return 
BTAG_SMS_PP_DOWNLOAD 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


11 


Check the TLV list conversion for 
EVENT_UNFORMATTED_SMS_PP_UPD 

1- An EVENT_UNFORMATTED_SMS_PP_UPD is sent 
to the (U)SIM. 

2- The findTLV(tag == device identities 
Tag) method is called. 

3- The getValueByte (of f set == 0) method is 
called. 

4- The getValueByte (of f set == 1) method is 
called. 

5- The findTLV(tag == address Tag) method 
is called. 

6- Check the content . 

7- The findTLV(tag == SMS TPDU Tag) method 
is called. 

8- Check the content. 


1- Applet is triggered. 

2- No exception is thrown. 

3- return the absolute record. 

4- return the record status. 

5- No exception is thrown. 

7- No exception is thrown. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


12 


getLengthO call 

Call getLengthO method 


return the Comprehension TLV list 
length 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


13 


getEnvelopeTagO call 

Call getEnvelopeTagO method 


return 

BTAG SMS PP DOWNLOAD 





5.3.3 Exception handling 
5.3.3.1 General Behaviour 

Test Area Reference: Ufw_Exh_Genb 



5.3.3.1.1 



5.3.3.1.1.1 



Conformance requirement 
Normal execution 



CRRNl: If more than one Applet shall be triggered by the currently processed event all Exceptions shall be 
caught by the USAT Framework and shall not be sent to the terminal. The USAT Framework shall proceed with 
the triggering. 

CRRN2: If only one Applet shall be triggered by the currently processed event and an ISOException with the 
reason code REPLY_BUSY is thrown, it shall be sent to the terminal using the Status Word 0x9300. 

CRRN3: If only one Applet shall be triggered by the currently processed event other Exceptions than an 
ISOException with the reason code REPLY_BUSY shall not be propagated to the terminal. 



5.3.3.1.1.2 

No requirements. 

5.3.3.1.1.3 

No requirements. 

5.3.3.1.2 

Test Source: 
Test Applet: 

Cap File: 
5.3.3.1.3 



Parameter errors 

Context errors 

Test area files 

Test_Ufw_Exh_Genb .j ava 
Ufw_Exh_Genb_ 1 .j ava 
Ufw_Exh_Genb_2.j ava 
ufw_exh_genb.cap 

Test coverage 



CRR Number 


Test Case Number 


CRRNl 


1,2,3,4 



5.3.3.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 





Appletl is installed and registers to 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




EVENT FORMATTED SMS PP ENV 
EVENT_UNFORMATTED_SMS_PP_ENV and 

Applet2 is installed and registers to 

EVENT UNFORMATTED SMS PP ENV and 

EVENT UNFORMATTED SMS CB 






1 


ISOException REPLY_BUSY is not sent to the 
terminal in multi triggering 

1- Send an envelope Event Unformatted SMS PP 
ENV (multi triggering event, multi registered 
applets) 

4- Send an envelope Event Unformatted SMS PP 
ENV (multi triggering event, multi registered 
applets) 


1- Appletl is triggered 

2- Appletl sends a ISOException 
with the reason code 
REPLY_BUSY then finalizes 

Applet2 is triggered, does nothing 
and finalizes 

4- Appletl is triggered, does 
nothing and finalizes 

Applet2 is triggered, sends a 
ISOException with the reason code 
REPLY_BUSY then finalizes 


3- SW = 90 00 
5- SW = 90 00 


2 


ISOException REPLY_BUSY is sent to the 
terminal in single triggering 

1 - Send an envelope Event formatted SMS PP 
ENV to trigger Appletl (single triggering event) 

2- Send an envelope Event Unformatted SMS CB 
(multi triggering event, single registered applet) 


1- Appletl is triggered, sends a 
ISOException with the reason code 
REPLY_BUSY then finalizes 

2- Applet2 is triggered, sends a 
ISOException with the reason code 
REPLY BUSY then finalizes 


1 - SW = 93 00 
2- SW = 93 00 


3 


Other exception than ISOException 
REPLY_BUSY are not sent to the terminal 

1- Send an envelope Event formatted SMS PP 
ENV to trigger Appletl (single triggering event) 

2- Send an envelope Event formatted SMS PP 
ENV to trigger Appletl (single triggering event) 


1- Appletl is triggered, sends a 
ISOException with reason code 
different to REPLY_BUSY then 
finalizes 

2- Appletl is triggered, sends a 
ToolkitException then finalizes 


1 - SW = 90 00 
2- SW = 90 00 



5.3.3.2 Interaction with Multiple Triggering 

Test Area Reference: Ufw_Exh_Imtg 

5.3.3.2.1 Conformance requirement 

5.3.3.2.1.1 Normal execution: 

• CRRNl: An exception thrown by a toolkit applet, will not influence toolkit applets registered to the same event. 

5.3.3.2.1 .2 Parameter errors 
No requirements. 
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5.3.3.2.1.3 


Context errors 


No requirements. 




5.3.3.2.2 


Test area files 


Test Source: 


Test_Ufw_Exh_Imtg.j ava 


Test Applet: 


Ufw_Exh_Imtg_ 1 .j ava 




Ufw_Exh_Imtg_2.j ava 


Cap File: 


ufw_exh_imtg.cap 


5.3.3.2.3 


Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2,3 



5.3.3.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 





Load/Install 2 toolkit applets registered to 

EVENT UNFORMATTED SMS PP ENV, 

EVENT UNFORMATTED SMS PP UPD, 

EVENT_UNFORMATTED_SMS_CB 

Appletl: Priority=0x01, 
Applet2: Priority^ 0x02, 
(i.e. Appletl is triggered before Applet2) 






1 


UNFORMATTED_SMS_PP_ENV is sent 


1- Appletl is triggered 

2- NullPointerException is thrown 

3- Applet2 is triggered 




2 


UNFORMATTED_SMS_PP_UPD is sent 


1- Appletl is triggered 

2- NullPointerException is thrown 

3- Applet2 is triggered 




3 


UNFORMATTED_SMS_CB is sent 


1- Appletl is triggered 

2- NullPointerException is thrown 

3- Applet2 is triggered 





5.3.4 Applet triggering 



5.3.4.1 EVENT_FORMATTED_SMS_PP_ENV 

Test Area Reference: Ufw_Apt_Efse 
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5.3.4.1.1 Conformance requirement 

5.3.4.1.1.1 Normal execution 

• CRRN 1 : The applet is triggered by the EVENT_FORMATTED_SMS_PP_EN V once: 

it has been registered to this event; 

a Short Message Point to Point (Single or Concatenated) is received by Envelope APDU(s) and is formatted 
according to TS 31.115 [10]; 

the toolkit applet to be triggered is registered with the corresponding TAR in the SMS TPDU; 

the security is verified. 

• CRRN2: The applet is not triggered by the EVENT_FORMATTED_SMS_PP_ENV once it has deregistered 
from this event. 



5.3.4.1.1.2 

No requirements. 

5.3.4.1.1.3 

No requirements. 

5.3.4.1.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.4.1.3 



Parameters error 

Context Errors 

Test area files 

Test_Ufw_Apt_Efse.j ava 
Ufw_ Apt_Ef se_ 1 .j ava 
ufw_apt_efse.cap 

Test coverage 



CRR Number 


Test Case Number 


CRRN1 (See note) 


1,2 


CRRN2 


2 



NOTE: The security checks are not relevant to the test designed in this test area; they will be checked in the 
"Framework Security Management" section. 



5.3.4.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Applet registration to EVENT 
FORMATTED_SMS_PP_ENV and triggering 

Applet is registered to 
EVENT_FORMATTED_SMS_PP_ENV and 
EVENT_UNRECOGNIZED_ENVELOPE 

1- A Single Short Message SMS-PP Formatted 
Data Download is sent to the USIM. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




2- A Concatenated Short Message SMS~PP 
Formatted Data Download is sent to the 
USIM (composed of 2 Short Messages. The 
DDL for the first Short Message is 70 and 
for the second 70) 


1- Applet is triggered 

2- Applet is triggered 




2 


Applet deregistration 

ToolkitRegistry . clearEvent method is 
called for EVENT_FORMATTED_SMS_PP_ENV 

1- A Single Short Message SMS-PP Data 
Download is sent to the USIM. 

2- A Concatenated Short Messages SMS-PP 
Data Download is sent to the USIM 

(composed of 2 Short Messages. The UDL for 
the first Short Message is 70 and for the 
second 70) . 

An unrecognized envelope is sent to the 

USIM 

ToolkitRegistry . setEvent method is 
called for EVENT_FORMATTED_SMS_PP_ENV 

3- A Single Short Messages SMS-PP Data 
Download is sent to the USIM. 

4- A Concatenated Short Messages SMS-PP 
Data Download is sent to the USIM 

(composed of 2 Short Messages. The UDL for 
the first Short Message is 70 and for the 
second 70) . 


1- Applet is not triggered 

2- Applet is not triggered 

3- Applet is triggered 

4- Applet is triggered 





5.3.4.2 EVENT_UNFORMATTED_SMS_PP_ENV 

Test Area Reference: Ufw_Apt_Euse 



5.3.4.2.1 



5.3.4.2.1.1 



Conformance requirement 
Normal execution 



CRRNl: The applets registers are triggered by the EVENT_UNFORMATTED_SMS_PP_ENV once a Short 
Message Point to Point (Single or Concatenated) is received by Envelope APDU(s) and is unformatted. 

CRRN2: The applet is not triggered by the EVENT_UNFORMATTED_SMS_PP_ENV once it has deregistered 
from this event. 



5.3.4.2.1.2 

No requirements. 

5.3.4.2.1.3 

No requirements. 

5.3.4.2.2 

Test Source: 
Test Applet: 



Parameters error 

Context Errors 

Test area files 

Test_Ufw_Apt_Euse.j ava 
Ufw_ Apt_Euse_ 1 .j ava 
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Cap File: 
5.3.4.2.3 



ufw_apt_euse.cap 
Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2 


CRRN2 


2 



5.3.4.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Applet registration to 

EVENT_UNFORMATTED_SMS_PP_ENV and 

triggering 

Applet is registered to the 
EVENT_UNFORMATTED_SMS_PP_ENV and 
EVENT_FORMATTED_SMS_PP_ENV . 








1-ToolkitRegistry .isEventSet method is 
called for EVENT_UNFORMATTED_SMS_PP_ENV 


1- The method returns true 






2- A Single and Unformatted SMS-PP Data 








Download Envelope is sent to the USIM. 


2- Applet is triggered 






3- A Concatenated and Unformatted SMS-PP 








Data Download Envelope is sent to the USIM 
(composed of 2 Short Messages. The UDL for 


3- Applet is triggered 






the first Short Message is 70 and for the 








second 70) 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


2 


Applet deregistration 

ToolkitRegistry . clear Event () method is 
called for EVENT_UNFORMATTED_SMS_PP„ENV 








1- A Single and Unformatted SMS-PP Data 


1 - Applet isn't triggered 






Download Envelope is sent to the USIM. 








2- A Concatenated and Unformatted SMS-PP 








Data Download Envelope is sent to the USIM 
(composed of 2 Short Messages. The UDL for 


2- Applet isn't triggered 






the first Short Message is 70 and for the 








second 70) 








An unrecognized envelope is sent to the 








USIM 








ToolkitRegistry . setEvent method is 








called for EVENT_UNFORMATTED_SMS_PP_ENV 








3- A Single and Unformatted SMS-PP Data 


3- Applet is triggered 






Download Envelope is sent to the USIM. 








4- A Concatenated and Unformatted SMS-PP 
Data Download Envelope is sent to the USIM 


4- Applet is triggered 






(composed of 2 Short Messages. The UDL for 








the first Short Message is 70 and for the 








second 70) 







5.3.4.3 EVENT_FORMATTED_SMS_PP_UPD 

Test Area Reference: Ufw_Apt_Efsu 

5.3.4.3.1 Conformance requirement 

5.3.4.3.1.1 Normal execution 

• CRRN 1 : The applet is triggered by the EVENT_FORMATTED_SMS_PP_UPD once: 

• it has been registered to this event, 

• a Short Message Point to Point (Single or Concatenated) is received by Update Record EFsms APDU(s) 
and is formatted according to TS 31.1 15[10], 

• the toolkit applet to be triggered is registered with the corresponding TAR in the SMS TPDU, 

• CRRN2: The applets are not triggered by the EVENT_FORMATTED_SMS_PP_UPD once it has deregistered 
from this event. 



5.3.4.3.2 

Test Source: 
Test Applet: 
Cap File: 



Test area files 

Test_Ufw_Apt_Efsu.j ava 
Ufw_ Apt_Ef su_ 1 .j ava 
ufw_apt_efsu.cap 
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5.3.4.3.3 



Test coverage 



CRR Number 


Test Case Number 


CRRN1 (See note) 


1,2 


CRRN2 


2 



NOTE: The security checks are not relevant to the test designed in this test area; they will be checked in the 
"Framework Security Management" section. 
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5.3.4.3.4 



Test procedure 



Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



Applet registration to EVENT 
FORMATTED_SMS_PP_UPD and triggering 



Applet is registered to 
EVENT_FORMATTED_SMS_PP_UPD and 
EVENT„UNRECOGNI ZED_ENVELOPE 

1. ToolkitRegistry . isEventSet ( ) method is 
called for EVENT_FORMATTED_SMS_PP_UPD 



2 . Short Message Point to Point Single and 
Formatted is received by Update Record 
EFsMs APDU. 



3. Short Message Point to Point 
Concatenated Formatted is received by 
Update Record EFsms APDU(s) (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



1- The method returns true. 



2- Applet is triggered. 



3- Applet is triggered on reception 
of the last concatenated SMS 



Applet deregistration 

ToolkitRegistry . clearEvent ( ) method is 
called for EVENT_FORMATTED_SMS_PP_UPD 

1 . Short Message Point to Point Single and 
Formatted is received by Update Record 
EFsMs APDU. 



2 . Short Message Point to Point 
Concatenated and Formatted is received by 
Update Record EFsms APDU(s). (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



An unrecognized envelope is sent to the 

USIM 

ToolkitRegistry . setEvent method is 
called for EVENT_FORMATTED_SMS_PP_UPD 

3. Short Message Point to Point Single and 
Formatted is received by Update Record 
EFsMs APDU. 

4. Short Message Point to Point 
Concatenated Formatted is received by 
Update Record EFsms APDU(s). (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



1- Applet is not triggered 



2- Applet is not triggered 



3- Applet is triggered 



4- Applet is triggered on reception 
of the last concatenated SMS. 



5.3.4.4 EVENT_UNFORMATTED_SMS_PP_UPD 

Test Area Reference: Ufw_Apt_Eusu 



£75/ 



3GPP TS 31.213 version 6.0.0 Release 6 



131 



ETSI TS 131 213 V6.0.0 (2007-03) 



5.3.4.4.1 



5.3.4.4.1.1 



Conformance requirement 
Normal execution 



• CRRN 1 : The applets registers are triggered by the EVENT_UNFORM ATTED_SMS_PP_UPD once a Short 
Message Point to Point (Single or Concatenated) is received by Update Record EFsms APDU(s) and is 
unformatted. 

• CRRN2: The applets are not triggered by the EVENT_UNFORMATTED_SMS_PP_UPD once it has 
deregistered from this event. 



5.3.4.4.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.4.4.3 



Test area files 

Test_Ufw_Apt_Eusu.j ava 
Ufw_ Apt_Eusu_ 1 .j ava 
ufw_apt_eusu.cap 

Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2 


CRRN2 


2 
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5.3.4.4.4 



Test procedure 



Id 



Description 



API/(U)SAT Framework 
Expectation 



APDU Expectation 



Applet registration to EVENT 
UNFORMATTED_SMS_PP_UPD and triggering 



Applet is registered to 
EVENT_UNFORMATTED_SMS_PP_UPD and 
EVENT UNRECOGNIZED ENVELOPE 



1. ToolkitRegistry . isEventSet ( ) method is 
called for EVENT_UNFORMATTED_SMS_PP_UPD 



2. Short Message Point to Point Single and 
Unformatted is received by Update Record 

EFsKs APDU 



3. Short Message Point to Point 
Concatenated and Unformatted is received 
by Update Record EFsms APDU (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



1 - Applet is not triggered 



2- Applet is triggered. 



3- Applet is triggered on reception 
of the last concatenated SIVIS. 



Applet deregistration 



ToolkitRegistry . clearEvent ( ) method is 
called for EVENT_UNFORMATTED_SMS_PP_UPD 

1. Short Message Point to Point Single and 
Unformatted is received by Update Record 

EFsKs APDU 



2. Short Message Point to Point 
Concatenated and Unformatted is received 
by Update Record EFsms APDU(s) (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



An unrecognized envelope is sent to the 
USIM 

ToolkitRegistry . setEvent () method is 
called for EVENT_UNFORMATTED_SMS_PP_UPD 

3. Short Message Point to Point Single and 
Unformatted is received by Update Record 

EFsKs APDU 

4. Short Message Point to Point 
Concatenated and Unformatted is received 
by Update Record EFsms APDU(s) (The 
Concatenated Message is composed of 2 
Short Messages. The UDL for the first 
Short Message is 70 and for the second 
70) . 



Applet is not triggered 



2- Applet is not triggered. 



3- Applet is triggered 



4- Applet is triggered on reception 
of {he last concatenated SMS 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 











5.3.4.5 EVENT_FORMATTED_SMS_CB 

Test Area Reference: Ufw_Apt_Efcb 

5.3.4.5.1 Conformance requirement 

5.3.4.5.1.1 Normal execution 

• CRRN 1 : The applet is triggered by the EVENT_FORMATTED_SMS_CB once: 

it has been registered to this event; 

an envelope APDU carrying a Cell Broadcast Page, formatted according to TS 31.1 15 [10] , is received; 

the toolkit applet to be triggered is registered with the corresponding TAR in the CB page; 

the security is verified. 

• CRRN2: The applet is not triggered by the EVENT_FORMATTED_SMS_CB once it has deregistered from this 
event. 



5.3.4.5.1.2 

No requirements. 

5.3.4.5.1.3 

No requirements. 

5.3.4.5.2 

Test Source: 
Test Applet: 
Cap File: 

5.3.4.5.3 



Parameters error 

Context Errors 

Test area files 

Test_Ufw_Apt_Efcb.java 
Ufw_ Apt_Efcb_ 1 .j ava 
ufw_apt_efcb . cap 

Test coverage 



CR Number 


Test Case Number 


CRRN1 (See note) 


1,2 


CRRN2 


2 


NOTE: The security checks are not relevant to the test 
designed in this test area; they will be checked in 
subclause 6.3.6. 



5.3.4.5.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Applet registration to 
EVENT_FORMATTED_SMS_CB and triggering 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Applet is registered to 
EVENT_FORMATTED_SMS_CB and 
EVENT_FORMATTED_SMS_PP„ENV 

1-An Envelope EVENT_FORMATTED_SMS_CB is 
sent to the DSIM. 


1 -Applet is triggered 




2 


Applet deregistration 

ToolkitRegistry . clearEvent ( ) method is 
called for EVENT_FORMATTED_SMS_CB 

1-A formatted SMS CB envelope is sent to 
the USIM. 

2-An envelope SMS-PP formatted is sent to 
the USIM 

ToolkitRegistry . setEvent method is 
called for EVENT_FORMATTED_SMS_CB 

3-An Envelope FORMATTED_SMS_CB is sent to 
the USIM 


1- Applet is not triggered 

2- Applet is triggered 

3- Applet is triggered 





5.3.4.6 EVENT_UNFORMATTED_SMS_CB 

Test Area Reference: Ufw_Apt_Eucb 

5.3.4.6.1 Conformance requirement 

5.3.4.6.1.1 Normal execution 

• CRRN 1 : The applet is triggered by the EVENT_UNFORMATTED_SMS_CB once it has registered to this event 
and an Envelope Cell Broadcast Download is received. 

• CRRN2: The applet is not triggered by the EVENT_UNFORMATTED_SMS_CB once it has deregistered from 
this event. 



5.3.4.6.1.2 

No requirements. 

5.3.4.6.1.3 

No requirements. 

5.3.4.6.2 

Test Source: 
Test Applet: 
Cap File: 



Parameters error 

Context Errors 

Test area files 

Test_Ufw_Apt_Eucb.java 
Ufw_ Apt_Eucb_ 1 .j ava 
ufw_apt_eucb.cap 
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5.3.4.6.3 



Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2 


CRRN2 


2 



5.3.4.6.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Applet registration to 

EVENT_UNFORMATTED_SMS_CB and 

triggering 

Applet is registered to the 
EVENT_UNFORMATTED_SMS_CB and 
EVENT_FORMATTED_SMS_PP_ENV . 

event= EVENT_UNFORMATTED_SMS_CB 
1-ToolkitRegistry.isEventSet method is 

called. 

2-An Envelope UNFORMATTED_SMS_CB is sent 
to the USIM. 


1- Method returns true. 

2- Applet is triggered 




2 


Applet deregistration 

ToolkitRegistry .ClearEvent Omethod is 
called for EVENT_UNFORMATTED_SMS_CB 

1-An Envelope DNFORMATTED_SMS_CB is sent 
to the USIM. 

An Envelope formatted SMS pp envelope is 
sent to the USIM 

event= EVENT_UNFORMATTED_SMS_CB 

ToolkitRegistry. setEvent method is called 
for EVENT„UNFORMATTED_SMS_CB 

2-An Envelope UNFORMATTED_SMS_CB is sent 
to the USIM. 


1- Applet isn't triggered 
2- Applet is triggered 





5.3.5 Envelope response posting 

5.3.5.1 EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 

Test Area Reference: Ufw_Erp_Emcn 

5.3.5.1.1 Conformance requirement 

5.3.5.1 .1 .1 Normal execution 
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• CRRNl: The (U)SAT Framework can't reply busy when an Envelope(MO-Short Message Control) is sent to 
the (U)SAT. 



5.3.6.2.1.2 

No requirements. 

5.3.6.2.1.3 

No requirements. 

5.3.5.1.2 

Test Source: 
Test Applet: 



Cap File: 
5.3.5.1.3 



Parameter errors 

Context errors 

Test area files 

Test_Ufw_Erp_Emcn. scr 
Ufw_Erp_Emcn_ 1 .j ava 
Ufw_Erp_Emcn_2 .j ava 
Ufw_Erp_Emcn_3 .j ava 
Uf w_Erp_Emcn . cap 

Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2 
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5.3.5.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Appletl is registered on the 

EVENT_MO_SHORT_MESSAGE_CONTROL_B 

Y SIM; Applet2 is registered and triggered on 

the EVENT_MENU_SELECTION. 

1 - Applet2 invokes the method send() and no fetch 
is performed 

2- Envelope{IVIO-SI\/l control) is sent to the (U)SAT 

3- Appletl calls the method 
EnvelopeResponseHandler.postAsBERTLVO to 
change any incoming TP_Destination_Address 
and any RP Destination Address of the Service 
Center into +1 1 22 33 44 

4- A Fetch command is sent to the (U)SAT 

5- A Terminal Response command is sent to the 
(U)SAT 

6- Delete Appletl & Applet2 

7- Install Applet3 


1- Applet2 is suspended 

2- Appletl is triggered. 

5- Applet2 execution shall continue. 


3- The U(SAT) answers 
91 XX to the Envelope(MO- 
Short Message Control) 
The new 

TPDestinationAddress 
and 

RP_Destination_Address 
are retrieved. 


2 


Applet3 is registered on both the events 

EVENT MO SHORT MESSAGE CONTROL B 

Y_SIM and EVENT_MENU_SELECTION. 

1 - Applet3 invokes the method send()and no fetch 
is performed 

2- Envelope{MO-SM control) is sent to the (U)SAT 

3- Applet3 calls the method 
EnvelopeResponseHandler.postAsBERTLVO to 
change any incoming TP_Destination_Address 
and any RP Destination Address of the Service 
Center into +1 1 22 33 44. 

4- A Fetch command is sent to the (U)SAT 

5- A Terminal Response command is sent to the 
(U)SAT 


1- Applets is suspended on the 
sendQ method 

2- Applets is triggered on the 
EVENT MO SHORT MESSAGE 
CONTROL_BY_SIM. 

5- Applets execution shall continue. 


3- The U(SAT) answers 
91 XX to the Envelope(MO- 
Short Message Control) 
The new 

TP_Destination_Address 
and 

RP_Destination_Address 
are retrieved. 



5.3.6 Toolkit installation 
5.3.6.1 Minimum security level 

Test Area Reference: ufw tin msl 
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5.3.6.1.1 



5.3.6.1.1.1 



Conformance requirements 
Normal execution 



CRRNl: The Receiving Entity shall check the Minimum Security Level during processing the security of the 
Command Packet. 

CRRN2: The Receiving Entity shall reject the message if the MSL check fails. 

CRRN3: If the MSL check fails, a Response Packet with the Tnsufficient Security Level' Response Status Code 
shall be sent if required. 

CRRN4: If the length of the Minimum Security Level field is greater than zero, the Minimum Security Level is 
used to specify the minimum level to be applied to Secured Packets. The first byte shall be the MSL Parameter, 
other bytes shall be the MSL Data. 

CRRN5: If the length of the Minimum Security Level field is zero, no minimum security level check shall be 
performed by the receiving entity. 



5.3.6.1.2 

Test source: 
Test Applet: 
Cap file: 

5.3.6.1.3 



Test area files 

Test_Ufw_Tin_Msl_l .Java 
Ufw_Tin_Msl_ 1 .j ava 
ufw_tin_msl.cap 

Test coverage 



CRR number 


Test case number 


CRRN1 


Not applicable 


CRRN2 


2 


CRRN3 


2 


CRRN4 


2 


CRRN5 


1 
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5.3.6.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Installation with MSL length of 

1- Install (install) applet with a MSL 
length = 

2- Send formatted SMS PP ENV with no 
RC/CC/DS, no Ciphering and counter mode 

(not checked) 

3- Send a formatted SMS PP ENV with CC, 
ciphering and counter mode 1 (counter 
available and no checking) 

4- Delete the applet instance 


2- Applet is triggered 

3- Applet is triggered 


1-SW = 9000 


2 


Installation with correct MSL value 

1- Install (install) applet with MSL field 
set to 02 (CC needed) . 

2- Send formatted SMS PP ENV with no 
RC/CC/DS, no Ciphering and counter mode 

(not checked) 

3- Send a formatted SMS PP ENV with CC, no 
ciphering and counter mode 1 counter 
available and no checking) 

4- Send a formatted SMS PP ENV with PoR 
required and no CC, ciphered with DES and 
counter mode counter available and no 
checking) 

5- Delete the applet instance 


2- Applet is not triggered 

3- Applet is triggered 

4- Applet is not triggered 


1-SW = 9000 

4- SW = 62 00, Response 
status code shall be 'DA', 
insufficient security level. 



5.3.6.2 TAR 

Test Area Reference: ufw_tin_tar 

5.3.6.2.1 Conformance requirements 

5.3.6.2.1.1 Normal execution 

• CRRNl: It is possible to define several TAR values at the installation of the Toolkit Application . 

• CRRN2: If the length of the TAR value is zero, the TAR may be taken out of the AID if any. 

• CRRN3: If the length of the TAR value is greater than zero then the application instance shall be installed with 
the TAR value field defined in parameter and the TAR indicated in the AID if any shall be ignored. 

• CRRN4: If the TAR value(s) is already assigned on the card for the Toolkit Application instance the card shall 
return the status word '6A 80', incorrect parameter in data field. 

• CRRN5: If the length of the TAR value(s) field is incorrect, the card shall return the status word '6 A 80', 
incorrect parameter in data field. 



5.3.6.2.2 

Test source: 
Test Applet: 
Cap file: 



Test area files 

Test_Ufw_Tin_Tar_l .scr 
uf w_tin_tar_ 1 .j a va 
ufw_tin_tar.cap 
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5.3.6.2.3 



Test Coverage 



CRR number 


Test case number 


CRRN1 


1 


CRRN2 


2 


CRRN3 


3 


CRRN4 


4 


CRRN5 


5 



5.3.6.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


ARDU Expectation 


1 


Installation with several TAR value 

1- Install (install) applet with no TAR 
defined in the AID but TAR values set to 
11 11 11, 22 22 22 

2- Send formatted SMS PP ENV with TAR set 
to 11 11 11. 

3- Send formatted SMS PP ENV with TAR set 
to 22 22 22. 

4- Delete the applet instance. 


2- Applet is triggered 

3- Applet is triggered 


1-SW = 9000 


2 


Installation without TAR value in install 
parameter 

1- Install (install) applet with TAR value 
length set to in install parameters . 

2- Send formatted SMS PP ENV with the TAR 
value defined in applet AID. 

3- Delete the applet instance 


2- Applet is triggered 


1-SW = 9000 


3 


Installation with TAR value within AID different 
from the one define in install parameters 

1- Install (install) applet with applet 
AID TAR set to XX YY ZZ and TAR value set 
to 11 11 11. 

2- Send formatted SMS PP ENV with the TAR 
value set to the one defined in applet 
AID. 

3- Send formatted SMS PP ENV with the TAR 
value set to 11 11 11. 


2- Applet is not triggered. 

3- Applet is triggered 




4 


Installation with TAR value already assigned 

1- Install (install) applet with no TAR in 
applet AID and TAR value in install 
parameters set to 11 11 11. 


1- Applet is not installed 


1-SW = 6A80 


5 


Installation with incorrect TAR value length in 
install parameters 

1- Install (install) applet with no TAR in 
applet AID and TAR value length set to 02 
and TAR value set to 11 11. 

2- Install (install) applet with no TAR in 
applet AID and TAR value length set to 05 
and TAR value set to 11 11 11,22 22. 


1- Applet is not installed 
2- Applet is not installed 


1-SW = 6A80 



5.3.6.3 Access domain 

Test Area Reference: ufw tin acdo 
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5.3.6.3.1 



5.3.6.3.1.1 



Conformance requirements 
Normal execution 



• CRRNl; The US AT framework shall grant files access to the application instance according to the US AT 
Framework access parameters. 

• CRRN2:The access rights granted to an application and defined in the access parameter shall be independent 
from the access rights granted at the USAT Framework/Terminal interface level. 

• CRRN3: If an application with access domain parameter set to 'FF' tries to access a file, the USAT framework 
shall throw an exception. 

• CRRN4: An application with access domain parameter set to '00' can perform all actions on files, except the ones 
with NEVER access conditions. 

• CRRN5: If a requested Access Domain is not supported, the card shall return the Status word '6 A 80' to the 
Install(install) command. 

• CRRN6: The card shall at least support the following Access Domain Parameter values: 

'00' : Full access to the file system 
'02' : UICC access mechanism 
'FF' : No access to the file system 

5.3.6.3.2 Test area files 

Test source: Test_Ufw_Tin_Acdo_l.java 

Test Applet: Ufw_Tin_Acdo_l.java 

Cap file: ufw_tin_acdo.cap 

5.3.6.3.3 Test coverage 



CRR number 


Test case number 


CRRN1 


1,2,3 


CRRN2 


1 


CRRN3 


2 


CRRN4 


3 


CRRN5 


Not testable 


CRRN6 


1,2,3 
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5.3.6.3.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


The access granted to an application shall be 

independent from the USAT 

Framework/Terminal interface 

1- Install (install) applet with Access 
domain parameter set to PINl 

2- Block PINl by sending unsuccessful 
verify pin command. 

3- Trigger the installed applet and try to 
increase EF_CUAC file with 

uicc. access . increase ( ) method. 

4- Delete the applet instance. 


3- no exception is thrown 




2 


Access domain parameter set to 'FF' 

1- Install (install) applet with access 
domain parameter set to 'FF'. 

2- Trigger the installed applet and try to 
access EF_TARU file with 

uicc . access . readBinary ( ) method. 

3- Delete the applet instance 


2- UlCCException. 
SECURITY_STATUS_NOT_SATIS 
FIED is thrown 




3 


Access domain parameter set to '00' 

1- Install (install) applet with access 
domain parameter set to '00'. 

2- Trigger the installed applet and try to 
access EF_TARU file using 

uicc . access . readBinary ( ) method. 

3- Trigger the applet and try to access 
the EF_TNU file using 

uicc. access . updateBinary ( ) method. 

4- Delete the applet instance 


2- No exception is thrown. 

3- UlCCException. 
SECURITY_STATUS_NOT_SATIS 
FIED is thrown 





5.3.7 Other parts transferred to (U)SAT framework from API 
5.3.7.1 A handler Is a temporary JCRE Entry Point object 

Test Area Reference: Ufw_Api_Hepo 

5.3.7.1.1 Conformance requirement 

5.3.7.1 .1 .1 Normal execution 

• CRRNl: The USATEnvelopeHandler is a Temporary JCRE Entry Point Object (see Java Card 2.2.1 Runtime 
Environment (JCRE) Specification [3]). 



5.3.7.1.1.2 

No requirements. 

5.3.7.1.1.3 

No requirements. 

5.3.7.1.2 



Parameter errors 



Context errors 



Test area files 



Test Source: Test_Ufw_Api_Hepo.java 
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CRR number 


Test case number 


CRRN1 


1,2 



5.3.7.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Storage In a static object 

Call USATEnvelopeHandler . getTheHandler ( ) 
method and store it in a static field of 
the toolkit applet 


SecurityException is thrown 




2 


Storage in a non-static object 

Call USATEnvelopeHandler . getTheHandler { ) 
method and store it in a non-static field 
of the toolkit applet 


SecurityException is tlirown 





5.3.8 Framework security management 

Security parameters 

The table that follows contains the security parameters that shall be used when the TS 31.115[10] security is required in 
the test cases developed in the current subclause. 



Parameter 


Value in hexadecimal 


KIC 


11 


KID 


11 


CNTR 


00 00 00 00 01 


Key for ciphering 


01 41 42 7F DA E8 91 A7 


Key for RC/CC/DS 


01 23 45 67 89 AB CD EF 



If a parameter is not listed explicitly in the above table, the default values of subclause 4.7.3.1 apply. 

5.3.8.1 Input data 

Test Area Reference: ufw fws inda 



5.3.8.1.1 



5.3.8.1.1.1 



Conformance requirements 
Normal execution 



CRRNl : If the US AT Framework receives an envelope APDU containing a Short Message Point to Point 
formatted according to TS 31.115 [10], it shall verify the security of the SMS TPDU and trigger the applet 
registered with the corresponding TAR. 

CRRN2: The toolkit applet will only be triggered if the TAR is known and the security verified. 
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CRRN3: If the US AT Framework receives an envelope APDU containing a Short message Cell Broadcast 
formatted according to TS 31.115 [10], it shall verify the security of the cell broadcast page and trigger the 
applet registered with the corresponding TAR. 

CRRN4: If the US AT Framework receives an Update Record EFsms instruction formatted according to 

TS 3 1 . 1 1 5 [ 1 0] , it shall verify the security of the SMS and trigger the applet registered with the corresponding 

TAR. 

CRRN5: The USAT Framework shall provide the input data deciphered. 



5.3.8.1.1.2 


Parameter errors 


No requirements. 




5.3.8.1.1.3 


Context errors 


No requirements. 




5.3.8.1.2 


Test area files 


Test source: 


Test_ufw_fws_inda_ 1 .j ava 


Test Applet: 


uf w_fws_inda_ 1 .j ava 




uf w_fws_inda_2 .j ava 




uf w_fws_inda_3 .j ava 




ufw_fws_inda_4.j ava 




uf w_fws_inda_5 .j ava 




uf w_fws_inda_6 .j ava 


Cap file: 


ufw_fws_inda.cap 


5.3.8.1.3 


Test coverage 



CRR Number 


Test Case Number 


CRRN1 


1,2,3 


CRRN2 


3,6,9 


CRRN3 


4,5,6 


CRRN4 


7,8,9 


CRRN5 


1,2,4,5,7,8 



5.3.8.1.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Framework checks the Cryptographic 
checksum and deciphers the data 

Appletl is loaded and installed 








1-Envelope (SMS-PP) single and formatted is 
sent to the USAT Framework with this 
features : 


1- Appletl is triggered and the 
value integrity is checked. 






Ciphering; 








Cryptographic checksum; 








No proof of receipt; 
TAR of Appletl; 




1 - The USAT Framework 




Data = 01 

2- Short Message concatenated and 




answers to the Envelope 
with status words 9000 




formatted is sent to the USAT Framework by 
an Envelope (SMS PP)with these features: 
Ciphering; 


2- Appletl is triggered and the 
value integrity is checked 






Cryptographic checksum; 








No proof of receipt; 








TAR of Appletl; 








Data length is 150. 




2- The USAT Framework 
answers to the Envelope 
with status words 9000 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


2 


Triggering two different applets with 
different security 

Applet2 is installed 

1-Envelope (SMS-PP) single and formatted is 








sent to the USAT Framework with this 


1- Appletl is triggered and the 






features : 


value integrity is checked 


1 - The USAT Framework 




Ciphering; 




answers to the Envelope 




Cryptographic checksum; 




with status words 9000 




No proof of receipt; 








TAR of Appletl 








Data = 03 








2- Short Message concatenated and 








formatted is sent to the USAT Framework by 








an Envelope (SMS PP)with these features: 


2- Appletl is triggered and the 


2- The USAT Framework 




Ciphering; 


value integrity is checked 


answers to the Envelope 




Cryptographic checksum; 




with status words 9000 




No proof of receipt; 








TAR of Appletl 








Data length = 150 




3- The USAT Framework 




3-Envelope (SMS-PP) single and formatted is 




answers to the Envelope 




sent to the USAT Framework with this 




with status words 9000 




features : 








No ciphering; 








No cryptographic checksum; 








No proof of receipt; 


3- Applet2 is triggered and the 






TAR of Applet2 


value integrity is checked 






Data = 05 




4- The USAT Framework 




4- Short Message concatenated and 




answers to the Envelope 




formatted is sent to the USAT Framework by 




with status words 9000 




an Envelope (SMS PP)with these features: 








No ciphering; 








No cryptographic checksum; 








No proof of receipt; 








TAR of Applet2 


4- Applet2 is triggered and the 






Data length = 150. 


value integrity is checked 




3 


Envelope(SMS-PP) formatted with wrong 




1 - The USAT Framework 




cryptographic checksum 




answers to the Envelope 
with status words 9000 




l-Envelope 03.48 single and formatted is 








sent to the USAT Framework with this 








features : 








No ciphering; 


1- No applet is triggered. 






Wrong cryptographic checksum; 








No proof of receipt; 








TAR of Appletl 








Data = 07 








2- Short Message concatenated and 








formatted is sent to the USAT Framework by 








an Envelope (SMS PP)with these features: 








No ciphering; 








Wrong cryptographic checksum; 








No proof of receipt; 


2- No applet is triggered. 






TAR of Appletl 








Data length = 150 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


4 


Framework checks the Cryptographic 
checksum and deciphers the data 

Applets is loaded and installed 

1-Envelope (SMS-CB) formatted is sent to 

the USAT Framework with this features: 

Ciphering; 

Cryptographic checksum; 

No proof of receipt; 

Data = 01 


1 - Applets is triggered and the 
value integrity is checked 


1 - The USAT Framework 
answers to the Envelope 
with status words 9000 


5 


Triggering two different applets with different 
security on Envelope(SMS-CB) formatted 

Applet4 is installed 

1-Envelope (SMS-CB) formatted is sent to 

the USAT Framework with this features: 

Ciphering; 

Cryptographic checksum; 

No proof of receipt; 

TAR of Applets 

Data = 02 

2-Envelope (SMS-CB) formatted is sent to 

the USAT Framework with this features! 

No ciphering; 

No cryptographic checksum; 

No proof of receipt; 

TAR of Applet4 

Data = 03 


1- Applets is triggered and the 
value integrity is checked 

2- Applet4 is triggered and the 
value integrity is checked 


1 - The USAT Framework 
answers to the Envelope 
with status words 9000 

2- The USAT Framework 
answers to the Envelope 
with status words 9000 


6 


Envelope(SMS-CB) formatted with wrong 
cryptographic checksum 

No ciphering; 

Wrong Cryptographic checksum; 

No proof of receipt; 

TAR of Applets 

Data = 04 


No applet is triggered 


1 - The USAT Framework 
answers to the Envelope 
with status words 9000 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


7 


Framework checks the Cryptographic 
checksum and deciphers the data 

Applets is installed 








1- Short Message single and formatted is 
sent to the USAT Framework by Update 
Record EFsms instruction with these 


1- Applets is triggered and the 
value integrity is checked. 


1 - The USAT Framework 
answers to the Update 




features : 




Record EFsms instruction 




Ciphering; 




with status words 9000 




Cryptographic checksum; 








No proof of receipt; 








TAR of Applets; 








Data = 01 








2- Short Message concatenated and 








formatted is sent to the USAT Framework by 




2- The USAT Framework 




Update Record EFsms instruction with these 


2- Applets is triggered and the 


answers to the Update 




features : 


value integrity is checked 


Record EFsms instruction 




Ciphering; 




with status words 9000 




Cryptographic checksum; 








No proof of receipt; 








TAR of Applets; 








Data length = ISO. 






8 


Triggering two different applets with different 
security 








Applet6 is installed 


1- Applets is triggered and the 








value integrity is checked. 


1 - The USAT Framework 




1- Short Message single and formatted is 




answers to the Update 




sent to the USAT Framework by Update 








Record EFsms instruction with these 




Record EFsms instruction 




features : 




with status words 9000 




Ciphering; 








Cryptographic checksum; 








No proof of receipt; 








TAR of Applets 








Data = 03 




2- The USAT Framework 




2- Short Message concatenated and 


2- Applets is triggered and the 


answers to the Update 




formatted is sent to the USAT Framework by 


value integrity is checked. 


Record EFsms instruction 




Update Record EFsms instruction with these 




with status words 9000 




features : 








Ciphering; 








Cryptographic checksum; 








No proof of receipt; 








TAR of Applets 
Data length = ISO. 




3- The USAT Framework 
answers to the Update 




3- Short Message single and formatted is 


3- Applets is triggered and the 


Record EFsms instruction 




sent to the USAT Framework by Update 


value integrity is checked. 


with status words 9000 




Record EFsms instruction with these 








features : 








No ciphering; 








No cryptographic checksum; 








No proof of receipt; 








TAR of Applet 6; 








Data = OS 




4- The USAT Framework 
answers to the Update 
Record EFsms instruction 




4- Short Message concatenated and 


4- Applets is triggered and the 


with status words 9000 




formatted is sent to the USAT Framework by 


value integrity is checked. 






Update Record EFsms instruction with these 








features : 








No ciphering; 








No cryptographic checksum; 








No proof of receipt; 








TAR of Applet 6; 








Data length = ISO. 
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Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


9 


Update Record EFsms instruction formatted 
with wrong cryptographic checksum 

1- Short Message single and formatted is 
sent to the USAT Framework by Update 
Record EFsms instruction with these 
features: No ciphering; 

Wrong Cryptographic checksum; 
No proof of receipt; 
TAR of Applets 
Data = 07 

2- Short Message concatenated and 
formatted is sent to the USAT Framework by 
Update Record EFsms instruction with these 
features : 

No ciphering; 

Wrong Cryptographic checksum; 

No proof of receipt; 

TAR of Applets 

Data length = ISO 


1- No applet is triggered. 

2- No applet is triggered. 


1 - The USAT Framework 
answers to the Update 
Record EFsms instruction 
with status words 9000 

2- The USAT Framework 
answers to the Update 
Record EFsms instruction 
with status words 9000 



5.3.8.2 Output data 

Test Area Reference: ufw_fws_ouda 

5.3.8.2.1 Conformance requirements 

5.3.8.2.1.1 Normal execution 

• CRRNl; The USAT Framework Toolkit Framework shall secure and send the response packet. 



5.3.8.2.1.2 

No requirements. 

5.3.8.2.1.3 

No requirements. 

5.3.8.2.2 

Test source: 
Test Applet: 
Cap file: 

5.3.8.2.3 



Parameters errors 

Context errors 

Test Area Files 

Test_Ufw_Fws_Ouda_l .Java 
Ufw_Fws_Ouda_ 1 .j ava 
Ufw_Fws_Ouda.cap 

Test coverage 



CRR Number 


Test Case Number 


CRRNl 


1,2,3,4 
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5.3.8.2.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 


1 


Envelope(SMS-PP) formatted 

ciphering; 

Cryptographic checksum; 

proof of receipt response shall be sent 

using SMS-Deliver-Report ; 

no security applied to proof of receipt 

Data in plain text = "APPLETl" 


The applet is triggered and sends a 
"Display Text" proactive command 
with the data received in the 
Envelope. 


The USAT Framework 
answers to the Envelope 
with a PoR which is 
retrieved and checked. 
The PoR has no application 
data. 

The USAT Framework 
answers with status words 
91 XX to issue a Display Text 
"APPLETl". 


2 


Envelope(SMS-PP) formatted 

ciphering; 

Cryptographic checksum; 

proof of receipt response shall be sent 

using SMS-Deliver-Report; 

no security applied to proof of receipt 

Data in plain text = "APPLETl" 


The applet posts application data. It 
does not call the 
ProactiveHandler.sendO method 


The USAT Framework 
answers to the Envelope 
with a PoR which is 
retrieved and checked. 
The PoR has the application 
data posted by the 
application. 


3 


Envelope(SMS-PP) formatted 

ciphering; 

Cryptographic checksum; 

proof of receipt response shall be sent 

using SMS-Deliver-Report; 

no security applied to proof of receipt 

Data in plain text = "TEST" 


The applet posts application data 
and calls the 

ProactiveHandler.sendO method to 
send a "Display Text" proactive 
command with the data received in 
the Envelope. 


The USAT Framework 
answers to the Envelope 
with a PoR which is 
retrieved and checked. The 
PoR has the application 
data posted by the 
application. 

The USAT Framework 
answers with status words 
91 XX to issue the Display 
Text "TEST". 


4 


Envelope(SMS-PP) formatted 

ciphering; 

Cryptographic checksum; 

proof of receipt response shall be sent 

using SMS-Deliver-Report; 

proof of receipt shall be ciphered 

Data in plain text = "TEST" 


The applet posts application data 
and calls the 

ProactiveHandler.sendO method to 
send a "Display Text" proactive 
command with the data received in 
the Envelope. 


The USAT Framework 
answers to the Envelope 
with a PoR which is 
retrieved and checked. The 
PoR has the application 
data posted by the 
application. 

The USAT Framework 
answers with status words 
91 XX to issue the Display 
Text "TEST". 



5.3.9 Concatenated SMS 
5.3.9.1 Concatenation processing 

Test Area Reference: Ufw Csm Proc 



5.3.9.1.1 



5.3.9.1.1.1 



Conformance requirements: 
Normal execution 



• CRRNl: When a Short Message is received as a Concatenated Short Message as defined in TS 23.040 [11], it 
is the responsibility of the (U)SAT Framework to link single Short Messages to reassemble the original 
message before any further processing. 

• CRRN2: The concatenation control headers, used to reassemble the short messages in the correct order, shall 
not be present in the SMS TPDU. 
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CRRN3: The TP-elements of the SMS TPDU and the Address (TS-Service-Centre-Address) shall correspond 
to the ones in the last received Short Message (independently of the Sequence number of Information- 
Element-Data). 

CRRN4: The original Short Message shall be placed in one SMS TPDU TLV (with TP-UDL field coded on 
one octet) included in the USATEnvelopeHandler. 

CRRN5: The (U)SAT Framework shall be able to process messages with the following properties as a 
minimum requirement: 

the Information Element Identifier is equal to the 8 -bit reference number 

it contains uncompressed 8 bit data or uncompressed UCS2 data 



5.3.9.2 

Test Source: 
Test Applet: 
Cap File: 



Test area files 

Test_Ufw_Csm_Proc.java 
Ufw_Csm_Proc_l .Java 
ufw_csm_proc.cap 



5.3.9.3 



Test coverage 



CRR number 


Test case number 


N1 


1,2,3,4, ,7,8, 9,10, , 13, 
14, 15, 18, 19,21,22 


N2 


5,17 


N3 


8,11,20, 19 


N4 


5,17 


N5 


12,24 



5.3.9.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Applet registration to 
EVENT_FORMATTED_SMS_PP_ENV and triggering 

Applet is registered to EVENT_FORMATTED_SMS_PP_ENV 
and EVENT_UNFORI^TTED„SMS_PP_ENV events 

A concatenated formatted SMS_PP is sent to the 
(U) SIM (composed of three segments). 






1 


The second segment of a concatenated short message 
is sent to the (U) SIM. 


Applet is not triggered. 




2 


The first segment of the concatenated short 
message is sent to the (U)SIM. 


Applet is not triggered. 




3 


The third segment of the concatenated short 
message is send to the (U) SIM 


Applet is triggered. 




4 


Call USATEnvelopeHandlerSystem.getTheHandler . 


No exception is thrown. 
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5 


Call the USATEnvelopeHandler.findTLVO to select 
the Dev Id, the address and the TPDU TLV and the 
USATEnvelopeHandler . compareValue ( ) to check each 
content . 


Check that the message has 
been re-assembled in the correct 
order. Check that TP-UDL field is 
coded in one octet. Check that 
the concatenation control header 
is not present in the message. 
Check the integrity of the 
message. 




6 


A new concatenated formatted short message is sent 
to the USIM composed of three segments. The 
Address fields of the first, second and the third 
segment are different. 


Applet is triggered. 




7 


Call USATEnvelopeHandlerSystem.getTheHandler . 


No exception is thrown. 




8 


Call USATEnvelopeHandlerSystem. findTLV to select 
the address TLV and the 

USATEnvelopeHandler . compareValue ( ) to check its 
content . 


Check that the address field of 
the message is equal to the 
address field of the third 
segment. 




9 


A new concatenated formatted short message is sent 
to the (U) SIM composed of three segments. Some TP 
elements of the TPDU of the first, second and 
third segment are different among themselves. 


Applet is triggered. 




10 


Call USATEnvelopeHandlerSystem. getTheHandler . 


No exception is thrown. 




11 


Call USATEnvelopeHandler.findTLVO to select the 
TP_DU TLV and USATEnvelopeHandler . compareValue ( ) 
to check its TP elements. 


Check that the TP elements of 
the message are equal to the 
ones of the third segment. 




12 


Send a concatenated formatted short message 
(composed of 3 segments) with uncompressed 8 bit 
data . 


Applet is triggered. 






Applet registration to 
EVENT_UNFORMATTED_SMS_PP_ENV and triggering 

Same test as above but with an unformatted SMS_PP 
envelope . 

A concatenated unformatted SMS_PP is sent to the 
(U) SIM (composed of three segments) . 






13 


The second segment of a concatenated short message 
is sent to the (U) SIM. 


Applet is not triggered. 




14 


The first segment of the concatenated short 
message is sent to the (U)SIM. 


Applet is not triggered. 




15 


The third segment of the concatenated short 
message is sent to the (U) SIM. 


Applet is triggered. 




16 


Call USATEnvelopeHanlderSystem. getTheHandler () 


No exception is thrown. 




17 


Call USATEnvelopeHandler.findTLVO to select the 
Dev Id, the address and the TPDU TLV and the 
USATEnvelopeHandler . compareValue ( ) to check each 
content . 


Check that the message has 
been reassembled in the correct 
order. Check that TP-UDL field is 
coded one octet. Check that the 
concatenation control header is 
not present in the message. 
Check the integrity of the 
message. 




18 


A new concatenated formatted short message is sent 
to the (U) SIM composed of three segments. The 
Address field of the first segment is different 
from the address field in the second segment. 


Applet is triggered. 




19 


Call USATEnvelopeHandlerSystem. getTheHandler . 


No exception is thrown. 




20 


Call USATEnvelopeHandler.findTLVO to select the 
address TLV and the 

USATEnvelopeHandler . compareValue to check its 
content . 


Check that the address field of 
the message is equal to the 
address field of the second 
segment. 




21 


A new concatenated unformatted short message is 
sent to the (U) SIM composed of two segments. Some 
TP_elements of the TPDU of the first, second and 
third segment are different. 


Applet is triggered. 
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22 


Call USATEnvelopeHandlerSystem.getTheHandler () 


No exception is tlirown. 




23 


Call USATEnvelopeHandler . findTLV to select the 
TPDU TLV and the 

USATEnvelopeHandler . compareValue to check its TP 
elements . 


Checl< that the TP elements of 
the message are equal to the 
ones of the third segment. 




24 


Send a concatenated unformatted short message 
(composed of 3 segments) with uncompressed UCS2 
data . 


Applet is triggered. 





5.3.10 Cell Broadcast Service 

5.3.10.1 Multiple message reassembling 

Test Area Reference: Ufw_Cbs_Mnira 
5.3.10.1.1 Conformance requirements: 

5.3.10.1.1.1 Normal execution 

• CRRNl: When a Cell Broadcast Message is received as multiple pages as defined in TS 23.041 [6], it is the 
responsibility of the (U)SAT Framework to link single pages together to re- assemble the original message 
before any further processing. 

• CRRN2: The original Cell Broadcast message shall be placed in one Cell Broadcast page TLV included in the 
US ATEnvelopeHandler. 

• CRRN3: The message parameters shall correspond to the ones in the last received Cell Broadcast page 
(independently of the Page Parameter). 

5.3.10.2 Test area files 

Test Source: Test_Ufw_Cbs_Mmra.java 

Test Applet: Ufw_Cbs_Mmra_l.java 

Cap File: Ufw_Cbs_Mmra.cap 

5.3.10.3 Test coverage 



CRR number 


Test case number 


N1 


1 -10 


N2 


5, 10 


N3 


5, 10 



5.3.10.4 



Test procedure 



Id 


Description 


API/(U)SAT Framework 
Expectation 


APDU Expectation 




Applet registration to EVENT_FORMATTED_SMS_CB 
and triggering 

Applet is registered to EVENT_FORMATTED_SMS_CB_ENV 
and EVENT_UNFORMATTED_SMS_CB_ENV events 

A multi page formatted SMS_CB is sent to the 
(U) SIM (composed of three segments). 
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1 


The first segment of a multi page formatted CB 
short message is sent to the (U)SIM. 


Applet is not triggered. 




2 


The second segment of a multi page formatted CB 
short message is sent to the USIM. 


Applet is not triggered. 




3 


The third segment of the multi page formatted CB 
short message is sent to the USIM. 


Applet is triggered. 




4 


Call USATEnvelopeHandlerSystem.getTheHandler . 


No exception is thrown. 




5 


Call USATEnvelopeHandler . compareValue ( ) to check 
message parameter, message integrity and message 
content . 


The message is re- assembled in 
the correct order with IVIessage 
Parameter of the third SI\/IS_CB 
which was sent at last. 






Applet registration to EVENT_UNFORMATTED_SMS_CB 
and triggering 

A multi page unformatted SMS_CB is sent to the 
(U) SIM (composed of three segments). 






6 


The second segment of a multi page unformatted 
SMS_CB is sent to the (U)SIM. 


Applet is not triggered. 




7 


The third segment of a multi page unformatted 
SMS_CB is sent to the (U)SIM. 


Applet is not triggered. 




8 


The first segment of a concatenated unformatted 
SMS_CB is sent to the (U) SIM. 


Applet is triggered. 




9 


Call USATEnvelopeHandlerSystem.getTheHandler . 


No exception is thrown. 




10 


Call USATEnvelopeHandler . compareValue ( ) to check 
message parameter, message integrity and message 
content . 


The message is re- assembled in 
the correct order with Page 
Parameter of first SI\/IS_CB which 
was sent at last. 
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Annex A (normative): 

Class, methods and USATFramework tests acronyms 



A.1 Toolkit part 



USATEnvelopeHandler 


Ueh 


USATEnvelopeHandler System 


Ues 


ToolkitRegistry 


Tkr 



A.1 .1 USATEnvelopeHandler interface 



Method name 


Acronyms 


short getSecuredDataLength 


Gsdl 


short getSecuredDataOffset 


Gsdo 


short getShortMessageLength ( ) 


GsmI 


short getShortMessageOf f set ( ) 


Gsmo 


short getTPUDLOffset 


Gtpo 


short getUserDataLength 


GudI 






Inherited method name: EnvelopeHandler 


Acronyms 


byte getChannelldentif ier ( ) 


Gcid 


short getChannelStatus (byte channelldentif ier) 


Gcst 


byte getltemldentifier 


Giid 






Inherited method name: BERTLVViewHandler 




short getsize ( ) 


Gtsz 


byte getTagO 


Gttg 






Inherited method name: ViewHandler 




byte compareValue (short valueOffset, byte[] 
compareBuf f er, short compareOf f set , short 
compare Length) 


Cprv 


short copy (byte [] dstBuffer, short dstOffset, short 
dstLength) 


Copy 


short copyValue (short valueOffset, byte[] dstBuffer, 
short dstOffset, short dstLength) 


Cpyv 


byte f indAndCompareValue (byte tag, byte[] 
compareBuf fer, short compareOf f set ) 


Facrb_Bs 


byte f indAndCompareValue (byte tag, byte occurrence, 
short valueOffset, byte[] compareBuf fer, short 
compareOf f set, short compareLength) 


Facrbbs_Bss 


short f indAndCopyValue (byte tag, byte[] dstBuffer, 
short dstOffset) 


Facyb_Bs 


short f indAndCopyValue (byte tag, byte occurrence, 
short valueOffset, byte[] dstBuffer, short 
dstOffset, short dstLength) 


Facybbs_Bss 


byte findTLV(byte tag, byte occurrence) 


Find 


short getCapacity ( ) 


Gcap 


short getLengthO 


Glen 


byte getValueByte (short valueOffset) 


Gvby 


short getValueLength 


Gvie 


short getValueShort (short valueOffset) 


Gvsh 
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A. 1.2 USATEnvelopeHandlerSystem method 



Method Name 


Acronyms 


public static USATEnvelopeHandler getTheHandler ( ) 


Gthd 



A.1 . 3 ToolkitRegistry methods 



Method Name 


Acronyms 


void clearEvent (short event) 


Cevt 


boolean isEventSet (short event) 


levs 


void setEvent (short event) 


Sevt 


void setEventList (short [ ] eventList, short offset, 
short length) 


SevI 



A.2 Acronyms for USATFramework tests 



Minimum liandler availability 


Mha 


Handler integrity 


Hin 


Applet triggering 


Apt 


Exception handling 


Exh 


Envelope response posting 


Erp 


Toolkit installation 


Tin 


Other parts transferred from API to CAT RE 


Api 


Framework Security 


Ufs 


Concatenated SIVIS 


Csm 


Cell Broadcast Service 


Cbs 



A.2.1 Minimum handler availability 



Test Area within the chapter 


Acronyms 


ProactiveHandler 


Pahd 


ProactiveResponseHandler 


Prhd 


EnvelopeHandler 


Enhd 


EnvelopeResponseHandler 


Erhd 


USATEnvelopeHandler 


Uehd 


Applet triggering with ongoing proactive session 


Rent 



A.2. 2 Handler integrity 



Test Area within the chapter 


Acronyms 


ProactiveResponseHandler 


Prhd 


EnvelopeHandler 


Enhd 


USATEnvelopeHandler 


Uehd 
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A.2.3 Applet triggering 



Test Area within the chapter 


Acronyms 







A.2.4 Exception handling 



IVIethod Name 


Acronyms 


General Behaviour 


Genb 


Interaction with Multiple Triggering 


Imtg 



A.2.5 Envelope response posting 



IVIethod Name 


Acronyms 


EVENT MO SHORT MESSAGE CONTROL BY SIM 


Emcn 



A.2.6 Toolkit installation 



Method Name 


Acronyms 


Access Domain 


Acdo 


Minimum Security Level 


Mslv 


TAR Value(s) of the Toolkit Application instance 


Tarv 



A.2.7 Other parts transferred from API to CAT RE 



Method Name 


Acronyms 


A handler is a temporary JCRE Entry Point object 


Hepo 



A.2.8 Framework security 



Method Name 


Acronyms 


Input Data 


Inda 


Output Data 


Ouda 
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A.2.9 Concatenated SMS 



Method Name 


Acronyms 


Concatenation processing 


Proc 



A.2.10 Cell Broadcast Service 



Method Name 


Acronyms 


IVIultiple message reassembling 


IVImra 
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Annex B (normative): 
Global prepersonalization 



The file system used to pass the test suite is described in ETSI TS 102 268 [15] Annex B, with one exception for file 

EFsMs- 



Name 


Identifier 


Description 


Special Notes 


EFsMS 


6F3C 


1"' record: 00 FF ... FF (length 176) 
2"" record: 00 FF ... FF (length 176) 
3'" record: 00 FF ... FF (length 176) 


The file EFsms should be present under both 
MF/DFtelecom and directly under ADF1 . One 
of these two EFsms files must be linked to the 
other one. 



Additionally, the following values must be used: 



Parameter 


Value in hexadecimal 


KIC 


11 


KID 


11 


CNTR 


00 00 00 00 01 


Key for ciphering 


01 41 42 7F DA E8 91 A7 


Key for RC/CC/DS 


01 23 45 67 89 AB CD EF 



The value for AppHcation PIN 1 (Global PIN 1) shall be "0x31 0x31 0x31 0x31 OxFF OxFF OxFF OxFF" and its state 
shall be 'disabled' during test applets execution. 

The value for Application PIN 1 block shall be "0x33 0x33 0x33 0x33 0x33 0x33 0x33 0x33" and its state shall be 
'disabled' during test applets execution. 
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Annex C (normative): 
Test file description 



Every test source is written in JAVAT"^ and shall use methods defined in Annex D interfaces to communicate with the 
card, or to check status word or received data. 

In order to be more readable, data specified as method string parameters shall be presented in 4 blocks of 4 bytes per 
line. Every block is separated by a space character. Every string line is appended to previous one and shall be aligned. 
An example is provided in Annex D. 

Every test file shall start with a call to reset() method. 
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Annex D (normative): 

uicc.usim.test.util package, (U)SIM interfaces and testing 

script example 

See attached files: 

Annex_D_UsimTestUtil.zip 

Annex_D_UsimInterfaces.zip 

Annex_D_Example.zip 
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Annex E (normative): 
Test Area files 

See attached file: 

Annex_E_SourceCode.zip 
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